Skip to content

[dotnet] Use namespace file scoped#15651

Merged
nvborisenko merged 1 commit intoSeleniumHQ:trunkfrom
nvborisenko:dotnet-namespace-file-scoped
Apr 20, 2025
Merged

[dotnet] Use namespace file scoped#15651
nvborisenko merged 1 commit intoSeleniumHQ:trunkfrom
nvborisenko:dotnet-namespace-file-scoped

Conversation

@nvborisenko
Copy link
Copy Markdown
Member

@nvborisenko nvborisenko commented Apr 20, 2025

User description

Simplify reading of .net code.

🔗 Related Issues

💥 What does this PR do?

I created .editorconfig file especially allocated for dotnet rules.

🔧 Implementation Notes

💡 Additional Considerations

It is massive change, now or later?

🔄 Types of changes

  • Cleanup (formatting, renaming)
  • Bug fix (backwards compatible)
  • New feature (non-breaking change which adds functionality and tests!)
  • Breaking change (fix or feature that would cause existing functionality to change)

PR Type

Enhancement


Description

  • Refactored all .NET source and test files to use file-scoped namespaces, modernizing code style and improving readability.

  • Flattened class and interface structures by removing unnecessary nesting and indentation, resulting in cleaner and more maintainable code.

  • No functional or logic changes; all updates are structural and formatting only.

  • Introduced a dedicated .editorconfig file to enforce consistent .NET code style rules across the project.


Changes walkthrough 📝

Relevant files
Formatting
9 files
WebDriver.cs
Refactor to file-scoped namespace for WebDriver class       

dotnet/src/webdriver/WebDriver.cs

  • Converted the namespace declaration to use file-scoped syntax.
  • Refactored the entire class to use file-scoped namespace, removing an
    extra indentation level.
  • No functional code changes, only formatting and structural update for
    improved readability.
  • +879/-880
    DriverOptions.cs
    Refactor to file-scoped namespace for DriverOptions           

    dotnet/src/webdriver/DriverOptions.cs

  • Changed the namespace declaration to file-scoped syntax.
  • Refactored the file to remove an indentation level, updating all code
    to align with file-scoped namespace.
  • No logic or functional changes, only formatting and structural
    improvements.
  • +450/-451
    SafariSpecificTests.cs
    Refactor SafariSpecificTests to file-scoped namespace       

    dotnet/test/safari/SafariSpecificTests.cs

  • Updated the namespace declaration to use file-scoped syntax.
  • Removed an unnecessary indentation level from the test class.
  • No changes to test logic or functionality.
  • +4/-5     
    ElementFindingTest.cs
    Refactor to file-scoped namespace and flatten test class structure

    dotnet/test/common/ElementFindingTest.cs

  • Converted the namespace declaration to use file-scoped syntax.
  • Removed an extra level of class nesting, making ElementFindingTest a
    top-level class in the file.
  • Reformatted all test methods to be direct members of the file-scoped
    namespace, removing indentation and braces associated with the
    previous nested class structure.
  • No functional changes to test logic; all changes are structural and
    formatting.
  • +838/-839
    RemoteWebDriver.cs
    Refactor to file-scoped namespace and reformat RemoteWebDriver

    dotnet/src/webdriver/Remote/RemoteWebDriver.cs

  • Changed the namespace declaration to file-scoped syntax.
  • Reformatted the entire class to remove one level of indentation, as a
    result of the file-scoped namespace.
  • No changes to logic or functionality; all changes are structural and
    formatting.
  • +508/-509
    DriverStartingEventArgs.cs
    Refactor to file-scoped namespace and flatten DriverStartingEventArgs
    class

    dotnet/test/common/Environment/DriverStartingEventArgs.cs

  • Changed the namespace declaration to file-scoped syntax.
  • Removed an extra level of class nesting, making
    DriverStartingEventArgs a top-level class in the file.
  • Reformatted property and constructor definitions to match the new
    structure.
  • No changes to logic or functionality; all changes are structural and
    formatting.
  • +12/-13 
    ExecutingJavascriptTest.cs
    Refactor to file-scoped namespace and flatten class structure in test
    file

    dotnet/test/common/ExecutingJavascriptTest.cs

  • Converted the namespace declaration to use file-scoped syntax.
  • Removed an extra level of class nesting, flattening the class
    structure.
  • Reformatted all test methods and code blocks to match the new
    file-scoped namespace style.
  • No logic changes, only structural and formatting updates for modern C#
    style.
  • +739/-740
    Actions.cs
    Refactor Actions class to file-scoped namespace and flatten structure

    dotnet/src/webdriver/Interactions/Actions.cs

  • Changed the namespace declaration to use file-scoped syntax.
  • Removed an extra level of class nesting, flattening the class
    structure.
  • Reformatted the entire file to match the file-scoped namespace style.
  • No logic changes, only structural and formatting updates for modern C#
    style.
  • +540/-541
    ILoadableComponent.cs
    Refactor ILoadableComponent to file-scoped namespace and flatten
    interface

    dotnet/src/support/UI/ILoadableComponent.cs

  • Changed the namespace declaration to use file-scoped syntax.
  • Flattened the interface definition by removing unnecessary braces and
    indentation.
  • Reformatted XML documentation comments to match the new structure.
  • No logic changes, only formatting and structure updates.
  • +23/-24 
    Additional files
    101 files
    .editorconfig +2/-0     
    EventFiringWebDriver.cs +1468/-1469
    FindElementEventArgs.cs +38/-39 
    GetShadowRootEventArgs.cs +22/-23 
    WebDriverExceptionEventArgs.cs +22/-23 
    WebDriverNavigationEventArgs.cs +31/-32 
    WebDriverScriptEventArgs.cs +22/-23 
    WebElementEventArgs.cs +22/-23 
    WebElementValueEventArgs.cs +19/-20 
    WebDriverExtensions.cs +94/-95 
    LoadableComponentException.cs +31/-32 
    LoadableComponent{T}.cs +96/-97 
    PopupWindowFinder.cs +101/-102
    SelectElement.cs +321/-322
    SlowLoadableComponent{T}.cs +92/-93 
    UnexpectedTagNameException.cs +41/-42 
    Alert.cs +48/-49 
    By.cs +317/-318
    CapabilityType.cs +176/-177
    ChromeDriver.cs +146/-147
    ChromeDriverService.cs +55/-56 
    ChromeOptions.cs +62/-63 
    ChromiumAndroidOptions.cs +18/-19 
    ChromiumDriver.cs +397/-398
    ChromiumDriverService.cs +157/-158
    ChromiumMobileEmulationDeviceSettings.cs +44/-45 
    ChromiumNetworkConditions.cs +86/-87 
    ChromiumOptions.cs +531/-532
    ChromiumPerformanceLoggingPreferences.cs +70/-71 
    Command.cs +127/-128
    CommandInfo.cs +71/-72 
    CommandInfoRepository.cs +102/-103
    Cookie.cs +293/-294
    CookieJar.cs +83/-84 
    DefaultFileDetector.cs +13/-14 
    DetachedShadowRootException.cs +31/-32 
    AuthRequiredEventArgs.cs +21/-22 
    BindingCalledEventArgs.cs +27/-28 
    CommandResponseException.cs +32/-33 
    CommandResponseExtensions.cs +13/-14 
    CommandResponseTypeMap.cs +42/-43 
    ConsoleApiArgument.cs +22/-23 
    ConsoleApiCalledEventArgs.cs +28/-29 
    DevToolsCommandData.cs +66/-67 
    DevToolsDomains.cs +96/-97 
    DevToolsEventData.cs +22/-23 
    DevToolsExtensionMethods.cs +60/-61 
    DevToolsOptions.cs +14/-15 
    DevToolsSession.cs +507/-508
    DevToolsSessionDomains.cs +18/-19 
    DevToolsSessionEventReceivedEventArgs.cs +27/-28 
    DevToolsSessionLogMessageEventArgs.cs +34/-35 
    DevToolsVersionInfo.cs +96/-97 
    EntryAddedEventArgs.cs +16/-17 
    ExceptionThrownEventArgs.cs +21/-22 
    ICommand.cs +19/-20 
    IDevTools.cs +39/-40 
    IDevToolsSession.cs +66/-67 
    JavaScript.cs +107/-108
    JsonEnumMemberConverter.cs +38/-39 
    Log.cs +31/-32 
    LogEntry.cs +21/-22 
    Network.cs +173/-174
    RequestPausedEventArgs.cs +21/-22 
    ResponsePausedEventArgs.cs +16/-17 
    Target.cs +63/-64 
    TargetAttachedEventArgs.cs +27/-28 
    TargetDetachedEventArgs.cs +21/-22 
    TargetInfo.cs +51/-52 
    WebSocketConnection.cs +223/-224
    WebSocketConnectionDataReceivedEventArgs.cs +16/-17 
    V133Domains.cs +38/-39 
    V133JavaScript.cs +139/-140
    V133Log.cs +46/-47 
    V133Network.cs +277/-278
    V133Target.cs +117/-118
    V134Domains.cs +38/-39 
    V134JavaScript.cs +139/-140
    V134Log.cs +46/-47 
    V134Network.cs +277/-278
    V134Target.cs +117/-118
    V135Domains.cs +38/-39 
    V135JavaScript.cs +139/-140
    V135Log.cs +46/-47 
    V135Network.cs +277/-278
    V135Target.cs +117/-118
    DomMutatedEventArgs.cs +13/-14 
    DomMutationData.cs +40/-41 
    DriverCommand.cs +466/-467
    DriverFinder.cs +114/-115
    DriverOptionsMergeResult.cs +12/-13 
    DriverProcessStartedEventArgs.cs +36/-37 
    DriverProcessStartingEventArgs.cs +18/-19 
    DriverService.cs +284/-285
    DriverServiceNotFoundException.cs +31/-32 
    EdgeDriver.cs +116/-117
    EdgeDriverService.cs +64/-65 
    EdgeOptions.cs +66/-67 
    ElementClickInterceptedException.cs +31/-32 
    ElementCoordinates.cs +36/-37 
    Additional files not shown

    Need help?
  • Type /help how to ... in the comments thread for any questions about Qodo Merge usage.
  • Check out the documentation for more information.
  • @selenium-ci selenium-ci added C-dotnet .NET Bindings B-support Issue or PR related to support classes labels Apr 20, 2025
    @selenium-ci
    Copy link
    Copy Markdown
    Member

    Thank you, @nvborisenko for this code suggestion.

    The support packages contain example code that many users find helpful, but they do not necessarily represent
    the best practices for using Selenium, and the Selenium team is not currently merging changes to them.

    We actively encourage people to add the wrapper and helper code that makes sense for them to their own frameworks.
    If you have any questions, please contact us

    @qodo-code-review
    Copy link
    Copy Markdown
    Contributor

    qodo-code-review bot commented Apr 20, 2025

    PR Reviewer Guide 🔍

    (Review updated until commit 866f81c)

    Here are some key observations to aid the review process:

    🎫 Ticket compliance analysis ❌

    1234 - Not compliant

    Non-compliant requirements:

    • Fix issue where JavaScript in link's href attribute is not triggered on click() in Firefox 42.0
    • Ensure compatibility between Selenium 2.48.x and Firefox 42.0
    • Make JavaScript execution in href attributes work consistently between Selenium versions

    5678 - Not compliant

    Non-compliant requirements:

    • Fix "Error: ConnectFailure (Connection refused)" when instantiating ChromeDriver after the first instance
    • Ensure multiple ChromeDriver instances can be created without connection errors
    • Address issue specific to Chrome 65.0.3325.181 with ChromeDriver 2.35 on Ubuntu 16.04.4

    ⏱️ Estimated effort to review: 2 🔵🔵⚪⚪⚪
    🧪 No relevant tests
    🔒 No security concerns identified
    ⚡ Recommended focus areas for review

    Code Readability

    The file-scoped namespace change significantly improves readability but should be verified for consistent indentation and formatting throughout the large file to ensure maintainability.

    namespace OpenQA.Selenium;
    
    /// <summary>
    /// A base class representing a driver for a web browser.
    /// </summary>
    public class WebDriver : IWebDriver, ISearchContext, IJavaScriptExecutor, IFindsElement, ITakesScreenshot, ISupportsPrint, IActionExecutor, IAllowsFileDetection, IHasCapabilities, IHasCommandExecutor, IHasSessionId, ICustomDriverCommandExecutor, IHasVirtualAuthenticator
    {
        /// <summary>
        /// The default command timeout for HTTP requests in a RemoteWebDriver instance.
        /// </summary>
        protected static readonly TimeSpan DefaultCommandTimeout = TimeSpan.FromSeconds(60);
        private IFileDetector fileDetector = new DefaultFileDetector();
        private NetworkManager network;
        private WebElementFactory elementFactory;
    
        private readonly List<string> registeredCommands = new List<string>();
    
        /// <summary>
        /// Initializes a new instance of the <see cref="WebDriver"/> class.
        /// </summary>
        /// <param name="executor">The <see cref="ICommandExecutor"/> object used to execute commands.</param>
        /// <param name="capabilities">The <see cref="ICapabilities"/> object used to configure the driver session.</param>
        protected WebDriver(ICommandExecutor executor, ICapabilities capabilities)
        {
            this.CommandExecutor = executor;
    
            try
            {
                this.StartSession(capabilities);
            }
            catch (Exception)
            {
                try
                {
                    // Failed to start driver session, disposing of driver
                    this.Quit();
                }
                catch
                {
                    // Ignore the clean-up exception. We'll propagate the original failure.
                }
                throw;
            }
    
            this.elementFactory = new WebElementFactory(this);
            this.registeredCommands.AddRange(DriverCommand.KnownCommands);
    
            if (this is ISupportsLogs)
            {
                // Only add the legacy log commands if the driver supports
                // retrieving the logs via the extension end points.
                this.RegisterDriverCommand(DriverCommand.GetAvailableLogTypes, new HttpCommandInfo(HttpCommandInfo.GetCommand, "/session/{sessionId}/se/log/types"), true);
                this.RegisterDriverCommand(DriverCommand.GetLog, new HttpCommandInfo(HttpCommandInfo.PostCommand, "/session/{sessionId}/se/log"), true);
            }
        }
    
        /// <summary>
        /// Gets the <see cref="ICommandExecutor"/> which executes commands for this driver.
        /// </summary>
        public ICommandExecutor CommandExecutor { get; }
    
        /// <summary>
        /// Gets the <see cref="ICapabilities"/> that the driver session was created with, which may be different from those requested.
        /// </summary>
        public ICapabilities Capabilities { get; private set; }
    
        /// <summary>
        /// Gets or sets the URL the browser is currently displaying.
        /// </summary>
        /// <seealso cref="IWebDriver.Url"/>
        /// <seealso cref="INavigation.GoToUrl(string)"/>
        /// <seealso cref="INavigation.GoToUrl(System.Uri)"/>
        public string Url
        {
            get
            {
                Response commandResponse = this.Execute(DriverCommand.GetCurrentUrl, null);
    
                commandResponse.EnsureValueIsNotNull();
                return commandResponse.Value.ToString()!;
            }
    
            set => new Navigator(this).GoToUrl(value);
        }
    
        /// <summary>
        /// Gets the title of the current browser window.
        /// </summary>
        public string Title
        {
            get
            {
                Response commandResponse = this.Execute(DriverCommand.GetTitle, null);
    
                return commandResponse.Value?.ToString() ?? string.Empty;
            }
        }
    
        /// <summary>
        /// Gets the source of the page last loaded by the browser.
        /// </summary>
        public string PageSource
        {
            get
            {
                Response commandResponse = this.Execute(DriverCommand.GetPageSource, null);
    
                commandResponse.EnsureValueIsNotNull();
                return commandResponse.Value.ToString()!;
            }
        }
    
        /// <summary>
        /// Gets the current window handle, which is an opaque handle to this
        /// window that uniquely identifies it within this driver instance.
        /// </summary>
        public string CurrentWindowHandle
        {
            get
            {
                Response commandResponse = this.Execute(DriverCommand.GetCurrentWindowHandle, null);
    
                commandResponse.EnsureValueIsNotNull();
                return commandResponse.Value.ToString()!;
            }
        }
    
        /// <summary>
        /// Gets the window handles of open browser windows.
        /// </summary>
        public ReadOnlyCollection<string> WindowHandles
        {
            get
            {
                Response commandResponse = this.Execute(DriverCommand.GetWindowHandles, null);
    
                commandResponse.EnsureValueIsNotNull();
                object?[] handles = (object?[])commandResponse.Value;
                List<string> handleList = new List<string>(handles.Length);
                foreach (object? handle in handles)
                {
                    handleList.Add(handle!.ToString()!);
                }
    
                return handleList.AsReadOnly();
            }
        }
    
        /// <summary>
        /// Gets a value indicating whether this object is a valid action executor.
        /// </summary>
        public bool IsActionExecutor => true;
    
        /// <summary>
        /// Gets the <see cref="Selenium.SessionId"/> for the current session of this driver.
        /// </summary>
        public SessionId SessionId { get; private set; }
    
        /// <summary>
        /// Gets or sets the <see cref="IFileDetector"/> responsible for detecting
        /// sequences of keystrokes representing file paths and names.
        /// </summary>
        /// <exception cref="ArgumentNullException">If value is set to <see langword="null"/>.</exception>
        public virtual IFileDetector FileDetector
        {
            get => this.fileDetector;
            set => this.fileDetector = value ?? throw new ArgumentNullException(nameof(value), "FileDetector cannot be null");
        }
    
        internal INetwork Network => this.network ??= new NetworkManager(this);
    
        /// <summary>
        /// Gets or sets the factory object used to create instances of <see cref="WebElement"/>
        /// or its subclasses.
        /// </summary>
        /// <exception cref="ArgumentNullException">If value is set to <see langword="null"/>.</exception>
        protected WebElementFactory ElementFactory
        {
            get => this.elementFactory;
            set => this.elementFactory = value ?? throw new ArgumentNullException(nameof(value));
        }
    
        /// <summary>
        /// Closes the Browser
        /// </summary>
        public void Close()
        {
            this.Execute(DriverCommand.Close, null);
        }
    
        /// <summary>
        /// Dispose the WebDriver Instance
        /// </summary>
        public void Dispose()
        {
            this.Dispose(true);
            GC.SuppressFinalize(this);
        }
    
        /// <summary>
        /// Executes JavaScript "asynchronously" in the context of the currently selected frame or window,
        /// executing the callback function specified as the last argument in the list of arguments.
        /// </summary>
        /// <param name="script">The JavaScript code to execute.</param>
        /// <param name="args">The arguments to the script.</param>
        /// <returns>The value returned by the script.</returns>
        public object? ExecuteAsyncScript(string script, params object?[]? args)
        {
            return this.ExecuteScriptCommand(script, DriverCommand.ExecuteAsyncScript, args);
        }
    
        /// <summary>
        /// Executes JavaScript in the context of the currently selected frame or window
        /// </summary>
        /// <param name="script">The JavaScript code to execute.</param>
        /// <param name="args">The arguments to the script.</param>
        /// <returns>The value returned by the script.</returns>
        public object? ExecuteScript(string script, params object?[]? args)
        {
            return this.ExecuteScriptCommand(script, DriverCommand.ExecuteScript, args);
        }
    
        /// <summary>
        /// Executes JavaScript in the context of the currently selected frame or window
        /// </summary>
        /// <param name="script">A <see cref="PinnedScript"/> object containing the JavaScript code to execute.</param>
        /// <param name="args">The arguments to the script.</param>
        /// <returns>The value returned by the script.</returns>
        /// <exception cref="ArgumentNullException">If <paramref name="script" /> is <see langword="null"/>.</exception>
        public object? ExecuteScript(PinnedScript script, params object?[]? args)
        {
            if (script == null)
            {
                throw new ArgumentNullException(nameof(script));
            }
    
            return this.ExecuteScript(script.MakeExecutionScript(), args);
        }
    
        /// <summary>
        /// Finds the first element in the page that matches the <see cref="By"/> object
        /// </summary>
        /// <param name="by">By mechanism to find the object</param>
        /// <returns>IWebElement object so that you can interact with that object</returns>
        /// <exception cref="ArgumentNullException">If <paramref name="by" /> is <see langword="null"/>.</exception>
        /// <example>
        /// <code>
        /// IWebDriver driver = new InternetExplorerDriver();
        /// IWebElement elem = driver.FindElement(By.Name("q"));
        /// </code>
        /// </example>
        public IWebElement FindElement(By by)
        {
            if (by == null)
            {
                throw new ArgumentNullException(nameof(@by), "by cannot be null");
            }
    
            return by.FindElement(this);
        }
    
        /// <summary>
        /// Finds an element matching the given mechanism and value.
        /// </summary>
        /// <param name="mechanism">The mechanism by which to find the element.</param>
        /// <param name="value">The value to use to search for the element.</param>
        /// <returns>The first <see cref="IWebElement"/> matching the given criteria.</returns>
        public virtual IWebElement FindElement(string mechanism, string value)
        {
            Dictionary<string, object> parameters = new Dictionary<string, object>();
            parameters.Add("using", mechanism);
            parameters.Add("value", value);
    
            Response commandResponse = this.Execute(DriverCommand.FindElement, parameters);
    
            return this.GetElementFromResponse(commandResponse)!;
        }
    
        /// <summary>
        /// Finds the elements on the page by using the <see cref="By"/> object and returns a ReadOnlyCollection of the Elements on the page
        /// </summary>
        /// <param name="by">By mechanism to find the element</param>
        /// <returns>ReadOnlyCollection of IWebElement</returns>
        /// <example>
        /// <code>
        /// IWebDriver driver = new InternetExplorerDriver();
        /// ReadOnlyCollection<![CDATA[<IWebElement>]]> classList = driver.FindElements(By.ClassName("class"));
        /// </code>
        /// </example>
        public ReadOnlyCollection<IWebElement> FindElements(By by)
        {
            if (by == null)
            {
                throw new ArgumentNullException(nameof(@by), "by cannot be null");
            }
    
            return by.FindElements(this);
        }
    
        /// <summary>
        /// Finds all elements matching the given mechanism and value.
        /// </summary>
        /// <param name="mechanism">The mechanism by which to find the elements.</param>
        /// <param name="value">The value to use to search for the elements.</param>
        /// <returns>A collection of all of the <see cref="IWebElement">IWebElements</see> matching the given criteria.</returns>
        public virtual ReadOnlyCollection<IWebElement> FindElements(string mechanism, string value)
        {
            Dictionary<string, object> parameters = new Dictionary<string, object>();
            parameters.Add("using", mechanism);
            parameters.Add("value", value);
    
            Response commandResponse = this.Execute(DriverCommand.FindElements, parameters);
    
            return this.GetElementsFromResponse(commandResponse);
        }
    
        /// <summary>
        /// Gets a <see cref="Screenshot"/> object representing the image of the page on the screen.
        /// </summary>
        /// <returns>A <see cref="Screenshot"/> object containing the image.</returns>
        public Screenshot GetScreenshot()
        {
            Response screenshotResponse = this.Execute(DriverCommand.Screenshot, null);
    
            screenshotResponse.EnsureValueIsNotNull();
            string base64 = screenshotResponse.Value.ToString()!;
            return new Screenshot(base64);
        }
    
        /// <summary>
        /// Gets a <see cref="PrintDocument"/> object representing a PDF-formatted print representation of the page.
        /// </summary>
        /// <param name="printOptions">A <see cref="PrintOptions"/> object describing the options of the printed document.</param>
        /// <returns>The <see cref="PrintDocument"/> object containing the PDF-formatted print representation of the page.</returns>
        /// <exception cref="ArgumentNullException">If <paramref name="printOptions"/> is <see langword="null"/>.</exception>
        public PrintDocument Print(PrintOptions printOptions)
        {
            if (printOptions is null)
            {
                throw new ArgumentNullException(nameof(printOptions));
            }
    
            Response commandResponse = this.Execute(DriverCommand.Print, printOptions.ToDictionary());
    
            commandResponse.EnsureValueIsNotNull();
            string base64 = commandResponse.Value.ToString()!;
            return new PrintDocument(base64);
        }
    
        /// <summary>
        /// Performs the specified list of actions with this action executor.
        /// </summary>
        /// <param name="actionSequenceList">The list of action sequences to perform.</param>
        public void PerformActions(IList<ActionSequence> actionSequenceList)
        {
            if (actionSequenceList == null)
            {
                throw new ArgumentNullException(nameof(actionSequenceList), "List of action sequences must not be null");
            }
    
            List<object> objectList = new List<object>();
            foreach (ActionSequence sequence in actionSequenceList)
            {
                objectList.Add(sequence.ToDictionary());
            }
    
            Dictionary<string, object> parameters = new Dictionary<string, object>();
            parameters["actions"] = objectList;
    
            this.Execute(DriverCommand.Actions, parameters);
        }
    
        /// <summary>
        /// Resets the input state of the action executor.
        /// </summary>
        public void ResetInputState()
        {
            this.Execute(DriverCommand.CancelActions, null);
        }
    
        /// <summary>
        /// Close the Browser and Dispose of WebDriver
        /// </summary>
        public void Quit()
        {
            this.Dispose();
        }
    
        /// <summary>
        /// Method to give you access to switch frames and windows
        /// </summary>
        /// <returns>Returns an Object that allows you to Switch Frames and Windows</returns>
        /// <example>
        /// <code>
        /// IWebDriver driver = new InternetExplorerDriver();
        /// driver.SwitchTo().Frame("FrameName");
        /// </code>
        /// </example>
        public ITargetLocator SwitchTo()
        {
            return new TargetLocator(this);
        }
    
        /// <summary>
        /// Instructs the driver to change its settings.
        /// </summary>
        /// <returns>An <see cref="IOptions"/> object allowing the user to change
        /// the settings of the driver.</returns>
        public IOptions Manage()
        {
            return new OptionsManager(this);
        }
    
        /// <summary>
        /// Instructs the driver to navigate the browser to another location.
        /// </summary>
        /// <returns>An <see cref="INavigation"/> object allowing the user to access
        /// the browser's history and to navigate to a given URL.</returns>
        public INavigation Navigate()
        {
            return new Navigator(this);
        }
    
        /// <summary>
        /// Executes a command with this driver.
        /// </summary>
        /// <param name="driverCommandToExecute">The name of the command to execute. The command name must be registered with the command executor, and must not be a command name known to this driver type.</param>
        /// <param name="parameters">A <see cref="Dictionary{K, V}"/> containing the names and values of the parameters of the command.</param>
        /// <returns>A <see cref="Response"/> containing information about the success or failure of the command and any data returned by the command.</returns>
        /// <exception cref="WebDriverException">The command returned an exceptional value.</exception>
        public object? ExecuteCustomDriverCommand(string driverCommandToExecute, Dictionary<string, object> parameters)
        {
            if (this.registeredCommands.Contains(driverCommandToExecute))
            {
                throw new WebDriverException(string.Format(CultureInfo.InvariantCulture, "A command named '{0}' is predefined by the driver class and cannot be executed with ExecuteCustomDriverCommand. It should be executed using a named method instead.", driverCommandToExecute));
            }
    
            return this.Execute(driverCommandToExecute, parameters).Value;
        }
    
        /// <summary>
        /// Registers a set of commands to be executed with this driver instance.
        /// </summary>
        /// <param name="commands">An <see cref="IReadOnlyDictionary{String, CommandInfo}"/> where the keys are the names of the commands to register, and the values are the <see cref="CommandInfo"/> objects describing the commands.</param>
        public void RegisterCustomDriverCommands(IReadOnlyDictionary<string, CommandInfo> commands)
        {
            foreach (KeyValuePair<string, CommandInfo> entry in commands)
            {
                this.RegisterCustomDriverCommand(entry.Key, entry.Value);
            }
        }
    
        /// <summary>
        /// Registers a command to be executed with this driver instance.
        /// </summary>
        /// <param name="commandName">The unique name of the command to register.</param>
        /// <param name="commandInfo">The <see cref="CommandInfo"/> object describing the command.</param>
        /// <returns><see langword="true"/> if the command was registered; otherwise, <see langword="false"/>.</returns>
        public bool RegisterCustomDriverCommand(string commandName, [NotNullWhen(true)] CommandInfo? commandInfo)
        {
            return this.RegisterDriverCommand(commandName, commandInfo, false);
        }
    
        /// <summary>
        /// Registers a command to be executed with this driver instance.
        /// </summary>
        /// <param name="commandName">The unique name of the command to register.</param>
        /// <param name="commandInfo">The <see cref="CommandInfo"/> object describing the command.</param>
        /// <param name="isInternalCommand"><see langword="true"/> if the registered command is internal to the driver; otherwise <see langword="false"/>.</param>
        /// <returns><see langword="true"/> if the command was registered; otherwise, <see langword="false"/>.</returns>
        internal bool RegisterDriverCommand(string commandName, [NotNullWhen(true)] CommandInfo? commandInfo, bool isInternalCommand)
        {
            if (this.CommandExecutor.TryAddCommand(commandName, commandInfo))
            {
                if (isInternalCommand)
                {
                    this.registeredCommands.Add(commandName);
                }
    
                return true;
            }
    
            return false;
        }
    
        /// <summary>
        /// Find the element in the response
        /// </summary>
        /// <param name="response">Response from the browser</param>
        /// <returns>Element from the page, or <see langword="null"/> if the response does not contain a dictionary.</returns>
        internal IWebElement? GetElementFromResponse(Response response)
        {
            if (response.Value is Dictionary<string, object?> elementDictionary)
            {
                return this.elementFactory.CreateElement(elementDictionary);
            }
    
            return null;
        }
    
        /// <summary>
        /// Finds the elements that are in the response
        /// </summary>
        /// <param name="response">Response from the browser</param>
        /// <returns>Collection of elements</returns>
        internal ReadOnlyCollection<IWebElement> GetElementsFromResponse(Response response)
        {
            List<IWebElement> toReturn = new List<IWebElement>();
            if (response.Value is object?[] elements)
            {
                foreach (object? elementObject in elements)
                {
                    if (elementObject is Dictionary<string, object?> elementDictionary)
                    {
                        WebElement element = this.elementFactory.CreateElement(elementDictionary);
                        toReturn.Add(element);
                    }
                }
            }
    
            return toReturn.AsReadOnly();
        }
    
        /// <summary>
        /// Executes a command with this driver.
        /// </summary>
        /// <param name="driverCommandToExecute">A <see cref="DriverCommand"/> value representing the command to execute.</param>
        /// <param name="parameters">A <see cref="Dictionary{K, V}"/> containing the names and values of the parameters of the command.</param>
        /// <returns>A <see cref="Response"/> containing information about the success or failure of the command and any data returned by the command.</returns>
        /// <exception cref="ArgumentNullException">If <paramref name="driverCommandToExecute"/> is <see langword="null"/>.</exception>
        protected internal virtual Response Execute(string driverCommandToExecute, Dictionary<string,
    #nullable disable
            object
    #nullable enable
            >? parameters)
        {
            return Task.Run(() => this.ExecuteAsync(driverCommandToExecute, parameters)).GetAwaiter().GetResult();
        }
    
        /// <summary>
        /// Executes a command with this driver.
        /// </summary>
        /// <param name="driverCommandToExecute">A <see cref="DriverCommand"/> value representing the command to execute.</param>
        /// <param name="parameters">A <see cref="Dictionary{K, V}"/> containing the names and values of the parameters of the command.</param>
        /// <returns>A <see cref="Response"/> containing information about the success or failure of the command and any data returned by the command.</returns>
        /// <exception cref="ArgumentNullException">If <paramref name="driverCommandToExecute"/> is <see langword="null"/>.</exception>
        protected internal virtual async Task<Response> ExecuteAsync(string driverCommandToExecute, Dictionary<string,
    #nullable disable
            object
    #nullable enable
            >? parameters)
        {
            Command commandToExecute = new Command(SessionId, driverCommandToExecute, parameters);
    
            Response commandResponse = await this.CommandExecutor.ExecuteAsync(commandToExecute).ConfigureAwait(false);
    
            if (commandResponse.Status != WebDriverResult.Success)
            {
                UnpackAndThrowOnError(commandResponse, driverCommandToExecute);
            }
    
            return commandResponse;
        }
    
        /// <summary>
        /// Starts a session with the driver
        /// </summary>
        /// <param name="capabilities">Capabilities of the browser</param>
        [MemberNotNull(nameof(SessionId))]
        [MemberNotNull(nameof(Capabilities))]
        protected void StartSession(ICapabilities capabilities)
        {
            Dictionary<string, object> parameters = new Dictionary<string, object>();
    
            // If the object passed into the RemoteWebDriver constructor is a
            // RemoteSessionSettings object, it is expected that all intermediate
            // and end nodes are compliant with the W3C WebDriver Specification,
            // and therefore will already contain all of the appropriate values
            // for establishing a session.
            if (capabilities is not RemoteSessionSettings remoteSettings)
            {
                Dictionary<string, object> matchCapabilities = this.GetCapabilitiesDictionary(capabilities);
    
                List<object> firstMatchCapabilitiesList = new List<object>();
                firstMatchCapabilitiesList.Add(matchCapabilities);
    
                Dictionary<string, object> specCompliantCapabilitiesDictionary = new Dictionary<string, object>();
                specCompliantCapabilitiesDictionary["firstMatch"] = firstMatchCapabilitiesList;
    
                parameters.Add("capabilities", specCompliantCapabilitiesDictionary);
            }
            else
            {
                parameters.Add("capabilities", remoteSettings.ToDictionary());
            }
    
            Response response = this.Execute(DriverCommand.NewSession, parameters);
    
            response.EnsureValueIsNotNull();
            if (response.Value is not Dictionary<string, object> rawCapabilities)
            {
                string errorMessage = string.Format(CultureInfo.InvariantCulture, "The new session command returned a value ('{0}') that is not a valid JSON object.", response.Value);
                throw new WebDriverException(errorMessage);
            }
    
            this.Capabilities = new ReturnedCapabilities(rawCapabilities);
    
            string sessionId = response.SessionId ?? throw new WebDriverException($"The remote end did not respond with ID of a session when it was required. {response.Value}");
            this.SessionId = new SessionId(sessionId);
        }
    
        /// <summary>
        /// Gets the capabilities as a dictionary.
        /// </summary>
        /// <param name="capabilitiesToConvert">The dictionary to return.</param>
        /// <returns>A Dictionary consisting of the capabilities requested.</returns>
        /// <remarks>This method is only transitional. Do not rely on it. It will be removed
        /// once browser driver capability formats stabilize.</remarks>
        /// <exception cref="ArgumentNullException">If <paramref name="capabilitiesToConvert"/> is <see langword="null"/>.</exception>
        protected virtual Dictionary<string, object> GetCapabilitiesDictionary(ICapabilities capabilitiesToConvert)
        {
            if (capabilitiesToConvert is null)
            {
                throw new ArgumentNullException(nameof(capabilitiesToConvert));
            }
    
            Dictionary<string, object> capabilitiesDictionary = new Dictionary<string, object>();
    
            foreach (KeyValuePair<string, object> entry in ((IHasCapabilitiesDictionary)capabilitiesToConvert).CapabilitiesDictionary)
            {
                if (CapabilityType.IsSpecCompliantCapabilityName(entry.Key))
                {
                    capabilitiesDictionary.Add(entry.Key, entry.Value);
                }
            }
    
            return capabilitiesDictionary;
        }
    
        /// <summary>
        /// Registers a command to be executed with this driver instance as an internally known driver command.
        /// </summary>
        /// <param name="commandName">The unique name of the command to register.</param>
        /// <param name="commandInfo">The <see cref="CommandInfo"/> object describing the command.</param>
        /// <returns><see langword="true"/> if the command was registered; otherwise, <see langword="false"/>.</returns>
        protected bool RegisterInternalDriverCommand(string commandName, [NotNullWhen(true)] CommandInfo? commandInfo)
        {
            return this.RegisterDriverCommand(commandName, commandInfo, true);
        }
    
        /// <summary>
        /// Stops the client from running
        /// </summary>
        /// <param name="disposing">if its in the process of disposing</param>
        protected virtual void Dispose(bool disposing)
        {
            try
            {
                if (this.SessionId is not null)
                {
                    this.Execute(DriverCommand.Quit, null);
                }
            }
            catch (NotImplementedException)
            {
            }
            catch (InvalidOperationException)
            {
            }
            catch (WebDriverException)
            {
            }
            finally
            {
                this.SessionId = null!;
            }
    
            this.CommandExecutor.Dispose();
        }
    
        private static void UnpackAndThrowOnError(Response errorResponse, string commandToExecute)
        {
            // Check the status code of the error, and only handle if not success.
            if (errorResponse.Status != WebDriverResult.Success)
            {
                if (errorResponse.Value is Dictionary<string, object?> errorAsDictionary)
                {
                    ErrorResponse errorResponseObject = new ErrorResponse(errorAsDictionary);
                    string errorMessage = errorResponseObject.Message;
                    switch (errorResponse.Status)
                    {
                        case WebDriverResult.NoSuchElement:
                            throw new NoSuchElementException(errorMessage);
    
                        case WebDriverResult.NoSuchFrame:
                            throw new NoSuchFrameException(errorMessage);
    
                        case WebDriverResult.UnknownCommand:
                            throw new NotImplementedException(errorMessage);
    
                        case WebDriverResult.ObsoleteElement:
                            throw new StaleElementReferenceException(errorMessage);
    
                        case WebDriverResult.ElementClickIntercepted:
                            throw new ElementClickInterceptedException(errorMessage);
    
                        case WebDriverResult.ElementNotInteractable:
                            throw new ElementNotInteractableException(errorMessage);
    
                        case WebDriverResult.InvalidElementState:
                            throw new InvalidElementStateException(errorMessage);
    
                        case WebDriverResult.Timeout:
                            throw new WebDriverTimeoutException(errorMessage);
    
                        case WebDriverResult.NoSuchWindow:
                            throw new NoSuchWindowException(errorMessage);
    
                        case WebDriverResult.InvalidCookieDomain:
                            throw new InvalidCookieDomainException(errorMessage);
    
                        case WebDriverResult.UnableToSetCookie:
                            throw new UnableToSetCookieException(errorMessage);
    
                        case WebDriverResult.AsyncScriptTimeout:
                            throw new WebDriverTimeoutException(errorMessage);
    
                        case WebDriverResult.UnexpectedAlertOpen:
                            // TODO(JimEvans): Handle the case where the unexpected alert setting
                            // has been set to "ignore", so there is still a valid alert to be
                            // handled.
                            string? alertText = null;
                            if (errorAsDictionary.TryGetValue("alert", out object? alert))
                            {
                                if (alert is Dictionary<string, object?> alertDescription
                                    && alertDescription.TryGetValue("text", out object? text))
                                {
                                    alertText = text?.ToString();
                                }
                            }
                            else if (errorAsDictionary.TryGetValue("data", out object? data))
                            {
                                if (data is Dictionary<string, object?> alertData
                                    && alertData.TryGetValue("text", out object? dataText))
                                {
                                    alertText = dataText?.ToString();
                                }
                            }
    
                            throw new UnhandledAlertException(errorMessage, alertText ?? string.Empty);
    
                        case WebDriverResult.NoAlertPresent:
                            throw new NoAlertPresentException(errorMessage);
    
                        case WebDriverResult.InvalidSelector:
                            throw new InvalidSelectorException(errorMessage);
    
                        case WebDriverResult.NoSuchDriver:
                            throw new WebDriverException(errorMessage);
    
                        case WebDriverResult.InvalidArgument:
                            throw new WebDriverArgumentException(errorMessage);
    
                        case WebDriverResult.UnexpectedJavaScriptError:
                            throw new JavaScriptException(errorMessage);
    
                        case WebDriverResult.MoveTargetOutOfBounds:
                            throw new MoveTargetOutOfBoundsException(errorMessage);
    
                        case WebDriverResult.NoSuchShadowRoot:
                            throw new NoSuchShadowRootException(errorMessage);
    
                        case WebDriverResult.DetachedShadowRoot:
                            throw new DetachedShadowRootException(errorMessage);
    
                        case WebDriverResult.InsecureCertificate:
                            throw new InsecureCertificateException(errorMessage);
    
                        case WebDriverResult.UnknownError:
                            throw new UnknownErrorException(errorMessage);
    
                        case WebDriverResult.UnknownMethod:
                            throw new UnknownMethodException(errorMessage);
    
                        case WebDriverResult.UnsupportedOperation:
                            throw new UnsupportedOperationException(errorMessage);
    
                        case WebDriverResult.NoSuchCookie:
                            throw new NoSuchCookieException(errorMessage);
    
                        default:
                            throw new InvalidOperationException(string.Format(CultureInfo.InvariantCulture, "{0} ({1})", errorMessage, errorResponse.Status));
                    }
                }
    
                throw new WebDriverException($"The {commandToExecute} command returned an unexpected error. {errorResponse.Value}");
            }
        }
    
        /// <summary>
        /// Executes JavaScript in the context of the currently selected frame or window using a specific command.
        /// </summary>
        /// <param name="script">The JavaScript code to execute.</param>
        /// <param name="commandName">The name of the command to execute.</param>
        /// <param name="args">The arguments to the script.</param>
        /// <returns>The value returned by the script.</returns>
        protected object? ExecuteScriptCommand(string script, string commandName, params object?[]? args)
        {
            object?[] convertedArgs = ConvertArgumentsToJavaScriptObjects(args);
    
            Dictionary<string, object> parameters = new Dictionary<string, object>();
            parameters.Add("script", script);
    
            if (convertedArgs != null && convertedArgs.Length > 0)
            {
                parameters.Add("args", convertedArgs);
            }
            else
            {
                parameters.Add("args", new object[] { });
            }
    
            Response commandResponse = this.Execute(commandName, parameters);
            return this.ParseJavaScriptReturnValue(commandResponse.Value);
        }
    
        private static object? ConvertObjectToJavaScriptObject(object? arg)
        {
            IWebDriverObjectReference? argAsObjectReference = arg as IWebDriverObjectReference;
    
            if (argAsObjectReference == null && arg is IWrapsElement argAsWrapsElement)
            {
                argAsObjectReference = argAsWrapsElement.WrappedElement as IWebDriverObjectReference;
            }
    
            object? converted;
    
            if (arg is string || arg is float || arg is double || arg is int || arg is long || arg is bool || arg == null)
            {
                converted = arg;
            }
            else if (argAsObjectReference != null)
            {
                Dictionary<string, object> webDriverObjectReferenceDictionary = argAsObjectReference.ToDictionary();
                converted = webDriverObjectReferenceDictionary;
            }
            else if (arg is IDictionary argAsDictionary)
            {
                // Note that we must check for the argument being a dictionary before
                // checking for IEnumerable, since dictionaries also implement IEnumerable.
                // Additionally, JavaScript objects have property names as strings, so all
                // keys will be converted to strings.
                Dictionary<string, object?> dictionary = new Dictionary<string, object?>();
                foreach (DictionaryEntry argEntry in argAsDictionary)
                {
                    dictionary.Add(argEntry.Key.ToString()!, ConvertObjectToJavaScriptObject(argEntry.Value));
                }
    
                converted = dictionary;
            }
            else if (arg is IEnumerable argAsEnumerable)
            {
                List<object?> objectList = new List<object?>();
                foreach (object? item in argAsEnumerable)
                {
                    objectList.Add(ConvertObjectToJavaScriptObject(item));
                }
    
                converted = objectList.ToArray();
            }
            else
            {
                throw new ArgumentException("Argument is of an illegal type: " + arg.ToString(), nameof(arg));
            }
    
            return converted;
        }
    
        /// <summary>
        /// Converts the arguments to JavaScript objects.
        /// </summary>
        /// <param name="args">The arguments.</param>
        /// <returns>The list of the arguments converted to JavaScript objects.</returns>
        private static object?[] ConvertArgumentsToJavaScriptObjects(object?[]? args)
        {
            if (args == null)
            {
                return new object?[] { null };
            }
    
            for (int i = 0; i < args.Length; i++)
            {
                args[i] = ConvertObjectToJavaScriptObject(args[i]);
            }
    
            return args;
        }
    
        private object? ParseJavaScriptReturnValue(object? responseValue)
        {
            object? returnValue;
    
            if (responseValue is Dictionary<string, object?> resultAsDictionary)
            {
                if (this.elementFactory.ContainsElementReference(resultAsDictionary))
                {
                    returnValue = this.elementFactory.CreateElement(resultAsDictionary);
                }
                else if (ShadowRoot.TryCreate(this, resultAsDictionary, out ShadowRoot? shadowRoot))
                {
                    returnValue = shadowRoot;
                }
                else
                {
                    // Recurse through the dictionary, re-parsing each value.
                    string[] keyCopy = new string[resultAsDictionary.Keys.Count];
                    resultAsDictionary.Keys.CopyTo(keyCopy, 0);
                    foreach (string key in keyCopy)
                    {
                        resultAsDictionary[key] = this.ParseJavaScriptReturnValue(resultAsDictionary[key]);
                    }
    
                    returnValue = resultAsDictionary;
                }
            }
            else if (responseValue is object?[] resultAsArray)
            {
                bool allElementsAreWebElements = true;
                List<object?> toReturn = new List<object?>(resultAsArray.Length);
                foreach (object? item in resultAsArray)
                {
                    object? parsedItem = this.ParseJavaScriptReturnValue(item);
                    if (parsedItem is not IWebElement)
                    {
                        allElementsAreWebElements = false;
                    }
    
                    toReturn.Add(parsedItem);
                }
    
                if (toReturn.Count > 0 && allElementsAreWebElements)
                {
                    List<IWebElement> elementList = new List<IWebElement>(resultAsArray.Length);
                    foreach (object? listItem in toReturn)
                    {
                        elementList.Add((IWebElement)listItem!);
                    }
    
                    returnValue = elementList.AsReadOnly();
                }
                else
                {
                    returnValue = toReturn.AsReadOnly();
                }
            }
            else
            {
                returnValue = responseValue;
            }
    
            return returnValue;
        }
    
        /// <summary>
        /// Creates a Virtual Authenticator.
        /// </summary>
        /// <param name="options"><see href="https://w3c.github.io/webauthn/#sctn-automation-virtual-authenticators">Virtual Authenticator Options</see>.</param>
        /// <returns> Authenticator id as string </returns>
        /// <exception cref="ArgumentNullException">If <paramref name="options"/> is <see langword="null"/>.</exception>
        public string AddVirtualAuthenticator(VirtualAuthenticatorOptions options)
        {
            if (options is null)
            {
                throw new ArgumentNullException(nameof(options));
            }
    
            Response commandResponse = this.Execute(DriverCommand.AddVirtualAuthenticator, options.ToDictionary());
    
            commandResponse.EnsureValueIsNotNull();
            string id = (string)commandResponse.Value;
            this.AuthenticatorId = id;
            return id;
        }
    
        /// <summary>
        /// Removes the Virtual Authenticator
        /// </summary>
        /// <param name="authenticatorId">Id as string that uniquely identifies a Virtual Authenticator.</param>
        /// <exception cref="ArgumentNullException">If <paramref name="authenticatorId"/> is <see langword="null"/>.</exception>
        public void RemoveVirtualAuthenticator(string authenticatorId)
        {
            if (authenticatorId is null)
            {
                throw new ArgumentNullException(nameof(authenticatorId));
            }
    
            Dictionary<string, object> parameters = new Dictionary<string, object>();
            parameters.Add("authenticatorId", authenticatorId);
    
            this.Execute(DriverCommand.RemoveVirtualAuthenticator, parameters);
            this.AuthenticatorId = null;
        }
    
        /// <summary>
        /// Gets the cached virtual authenticator ID, or <see langword="null"/> if no authenticator ID is set.
        /// </summary>
        public string? AuthenticatorId { get; private set; }
    
        /// <summary>
        /// Add a credential to the Virtual Authenticator/
        /// </summary>
        /// <param name="credential"> The credential to be stored in the Virtual Authenticator</param>
        /// <exception cref="ArgumentNullException">If <paramref name="credential"/> is <see langword="null"/>.</exception>
        /// <exception cref="InvalidOperationException">If a Virtual Authenticator has not been added yet.</exception>
        public void AddCredential(Credential credential)
        {
            if (credential is null)
            {
                throw new ArgumentNullException(nameof(credential));
            }
    
            string authenticatorId = this.AuthenticatorId ?? throw new InvalidOperationException("Virtual Authenticator needs to be added before it can perform operations");
    
            Dictionary<string, object> parameters = new Dictionary<string, object>(credential.ToDictionary());
            parameters.Add("authenticatorId", authenticatorId);
    
            this.Execute(driverCommandToExecute: DriverCommand.AddCredential, parameters);
        }
    
        /// <summary>
        /// Retrieves all the credentials stored in the Virtual Authenticator
        /// </summary>
        /// <returns> List of credentials </returns>
        /// <exception cref="InvalidOperationException">If a Virtual Authenticator has not been added yet.</exception>
        public List<Credential> GetCredentials()
        {
            string authenticatorId = this.AuthenticatorId ?? throw new InvalidOperationException("Virtual Authenticator needs to be added before it can perform operations");
    
            Dictionary<string, object> parameters = new Dictionary<string, object>();
            parameters.Add("authenticatorId", authenticatorId);
    
            Response getCredentialsResponse = this.Execute(driverCommandToExecute: DriverCommand.GetCredentials, parameters);
    
            getCredentialsResponse.EnsureValueIsNotNull();
            if (getCredentialsResponse.Value is not object?[] credentialsList)
            {
                throw new WebDriverException($"Get credentials call succeeded, but the response was not a list of credentials: {getCredentialsResponse.Value}");
            }
    
            List<Credential> credentials = new List<Credential>(credentialsList.Length);
            foreach (object? dictionary in credentialsList)
            {
                Credential credential = Credential.FromDictionary((Dictionary<string, object>)dictionary!);
                credentials.Add(credential);
            }
    
            return credentials;
        }
    
        /// <summary>
        /// Removes the credential identified by the credentialId from the Virtual Authenticator.
        /// </summary>
        /// <param name="credentialId"> The id as byte array that uniquely identifies a credential </param>
        /// <exception cref="ArgumentNullException">If <paramref name="credentialId"/> is <see langword="null"/>.</exception>
        /// <exception cref="InvalidOperationException">If a Virtual Authenticator has not been added yet.</exception>
        public void RemoveCredential(byte[] credentialId)
        {
            RemoveCredential(Base64UrlEncoder.Encode(credentialId));
        }
    
        /// <summary>
        /// Removes the credential identified by the credentialId from the Virtual Authenticator.
        /// </summary>
        /// <param name="credentialId"> The id as string that uniquely identifies a credential </param>
        /// <exception cref="ArgumentNullException">If <paramref name="credentialId"/> is <see langword="null"/>.</exception>
        /// <exception cref="InvalidOperationException">If a Virtual Authenticator has not been added yet.</exception>
        public void RemoveCredential(string credentialId)
        {
            if (credentialId is null)
            {
                throw new ArgumentNullException(nameof(credentialId));
            }
    
            string authenticatorId = this.AuthenticatorId ?? throw new InvalidOperationException("Virtual Authenticator needs to be added before it can perform operations");
    
            Dictionary<string, object> parameters = new Dictionary<string, object>();
            parameters.Add("authenticatorId", authenticatorId);
            parameters.Add("credentialId", credentialId);
    
            this.Execute(driverCommandToExecute: DriverCommand.RemoveCredential, parameters);
        }
    
        /// <summary>
        /// Removes all the credentials stored in the Virtual Authenticator.
        /// </summary>
        /// <exception cref="InvalidOperationException">If a Virtual Authenticator has not been added yet.</exception>
        public void RemoveAllCredentials()
        {
            string authenticatorId = this.AuthenticatorId ?? throw new InvalidOperationException("Virtual Authenticator needs to be added before it can perform operations");
    
            Dictionary<string, object> parameters = new Dictionary<string, object>();
            parameters.Add("authenticatorId", authenticatorId);
    
            this.Execute(driverCommandToExecute: DriverCommand.RemoveAllCredentials, parameters);
        }
    
        /// <summary>
        ///  Sets the isUserVerified property for the Virtual Authenticator.
        /// </summary>
        /// <param name="verified">The boolean value representing value to be set </param>
        public void SetUserVerified(bool verified)
        {
            string authenticatorId = this.AuthenticatorId ?? throw new InvalidOperationException("Virtual Authenticator needs to be added before it can perform operations");
    
            Dictionary<string, object> parameters = new Dictionary<string, object>();
            parameters.Add("authenticatorId", authenticatorId);
            parameters.Add("isUserVerified", verified);
    
            this.Execute(driverCommandToExecute: DriverCommand.SetUserVerified, parameters);
        }
    }

    @qodo-code-review
    Copy link
    Copy Markdown
    Contributor

    qodo-code-review bot commented Apr 20, 2025

    PR Code Suggestions ✨

    Latest suggestions up to 866f81c
    Explore these optional code suggestions:

    CategorySuggestion                                                                                                                                    Impact
    Possible issue
    Consistent empty selector behavior

    The test expects that finding elements with an empty CSS selector should throw
    an exception, but in many browsers and WebDriver implementations, this might
    return an empty collection instead. Consider making the test consistent with the
    behavior of FindingMultipleElementsByEmptyIdShouldReturnEmptyList() which
    expects an empty collection rather than an exception.

    dotnet/test/common/ElementFindingTest.cs [625-629]

     [Test]
    -public void FindingMultipleElementsByEmptyCssSelectorShouldThrow()
    +public void FindingMultipleElementsByEmptyCssSelectorShouldReturnEmptyList()
     {
         driver.Url = xhtmlTestPage;
    -    Assert.That(() => driver.FindElements(By.CssSelector("")), Throws.InstanceOf<WebDriverException>());
    +    ReadOnlyCollection<IWebElement> elements = driver.FindElements(By.CssSelector(""));
    +    Assert.That(elements, Is.Empty);
     }

    [To ensure code accuracy, apply this suggestion manually]

    Suggestion importance[1-10]: 7

    __

    Why: The suggestion correctly identifies an inconsistency in how empty selectors are handled. The test expects an exception for empty CSS selectors but expects empty collections for empty ID selectors, which could lead to test failures if browser implementations change. Making the behavior consistent improves test reliability.

    Medium
    • More

    Previous suggestions

    Suggestions up to commit 866f81c
    CategorySuggestion                                                                                                                                    Impact
    General
    Remove null-forgiving operator

    The code is using the null-forgiving operator (!) to suppress the non-null
    warning on SessionId, but this could lead to potential null reference
    exceptions. Instead, consider using a proper null check before accessing the
    property or making the property nullable.

    dotnet/src/webdriver/WebDriver.cs [705]

    -this.SessionId = null!;
    +this.SessionId = null;
    Suggestion importance[1-10]: 3

    __

    Why: The suggestion correctly identifies the use of the null-forgiving operator, but its impact is limited. The property is marked with [MemberNotNull] attribute elsewhere, indicating it should never be null during normal operation. Removing the operator would cause compiler warnings since SessionId is likely non-nullable by design.

    Low

    @nvborisenko
    Copy link
    Copy Markdown
    Member Author

    Hey bot, your opinion is useful, but please suggest rather than decide.

    @nvborisenko nvborisenko reopened this Apr 20, 2025
    @nvborisenko nvborisenko merged commit 56c9d29 into SeleniumHQ:trunk Apr 20, 2025
    25 checks passed
    @nvborisenko nvborisenko deleted the dotnet-namespace-file-scoped branch April 20, 2025 20:21
    PhilipWoulfe pushed a commit to PhilipWoulfe/F1Competition that referenced this pull request Mar 16, 2026
    Updated [Selenium.Support](https://github.com/SeleniumHQ/selenium) from
    4.31.0 to 4.41.0.
    
    <details>
    <summary>Release notes</summary>
    
    _Sourced from [Selenium.Support's
    releases](https://github.com/SeleniumHQ/selenium/releases)._
    
    ## 4.41.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    <!-- Release notes generated using configuration in .github/release.yml
    at selenium-4.41.0 -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [py] Remove type stub packages from runtime dependencies by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16945
    * Canonical approach to supporting AI agent directions by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16735
    * [build] Pre-release workflow improvements by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16946
    * [build] Prevent nightly releases during release window by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16948
    * [build] Fix Bazel NuGet push implementation by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16950
    * [build] Release workflow improvements by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16947
    * [build] Fix Bazel JSDocs implementation by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16949
    * [build] Create config files from environment variables for publishing
    by @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16951
    * [js] create task to update dependencies by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16942
    * [build] Java release improvements and build verification tasks by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16952
    * [py] integrate mypy type checking with Bazel by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16958
    * [build] Migrate workflows to use centralized bazel.yml by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16955
    * [dotnet] [bidi] Simplify context aware command options by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16954
    * [build] simplify release.yml: remove draft, build once during publish
    by @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16960
    * [dotnet] [bidi] AOT safe json converter for `Input.Origin` class by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16962
    * [dotnet] [bidi] AOT safe json converter for `OptionalConverter` by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16963
    * [dotnet] [bidi] Null guard for event handlers by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16967
    * [java] Improve error message for died grid by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16938
    * [build] combine pre-release dependency updates by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16973
    * [rb] remove stored atoms these get generated by build by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16971
    * [dotnet] [bidi] Unignore some internal tests by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16968
    * [build] run ruff on python files outside py directory by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16957
    * [py] Fix return type hint for `alert_is_present` by @​nemowang2003 in
    https://github.com/SeleniumHQ/selenium/pull/16975
    * Replace hardcoded bazel-selenium references with dynamic path
    resolution by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16976
    * No More CrazyFun! by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16972
    * [build] Remove update_gh_pages in favor of CI workflow by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16977
    * [build] Remove legacy rake helpers and unused code by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16978
    * [py] make bazel test target names consistent with other languages by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16969
    * [dotnet] [bidi] Fix namespace for Permissions module by @​nvborisenko
    in https://github.com/SeleniumHQ/selenium/pull/16981
    * [dotnet] [bidi] Hide Broker as internal implementation by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16982
    * [dotnet] [bidi] Refactor BiDi module initialization to pass BiDi
    explicitly by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16983
    * [build] Add DocFX updater script by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16980
    * [build] add reusable commit-changes.yml workflow by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16965
    * [java] fix JSON parsing of numbers with exponent by @​joerg1985 in
    https://github.com/SeleniumHQ/selenium/pull/16961
    * [build] Skip macOS-only archive rules on unsupported platforms by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16985
    * [build] Split Rakefile into per-language task files by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16979
    * Implement fast bazel target lookup with index caching by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16974
    * [build] Remove git.add() calls from rake tasks by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16994
    * [js] Add eslint binary target for selenium-webdriver by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16992
     ... (truncated)
    
    ## 4.40.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at trunk -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [dotnet] Modernize `EnvironmentManager`, standardize assembly teardown
    by @​RenderMichael in https://github.com/SeleniumHQ/selenium/pull/15551
    * [java] Refactor tests by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16684
    * [ci]: bump cargo lockfile by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16698
    * [java][BiDi] change emulation commands return type to void by
    @​Delta456 in https://github.com/SeleniumHQ/selenium/pull/16699
    * [java] simplify strings processing by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/15309
    * Fix few more flaky ruby tests by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16695
    * [bazel] Switch to custom `closure_js_deps` rule by @​shs96c in
    https://github.com/SeleniumHQ/selenium/pull/16571
    * [dotnet] [bidi] Support SetScreenSettingsOverrideAsync method in
    Emulation module by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16704
    * [dotnet] Modernize code patterns in test suites by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/16701
    * use proper AssertJ asserts that generate a useful error message by
    @​asolntsev in https://github.com/SeleniumHQ/selenium/pull/16707
    * fix Java language level in IDEA by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16708
    * [py] Properly verify Selenium Manager exists by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16711
    * fix flaky Ruby test `element_spec.rb` by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16709
    * [java][BiDi] implement `emulation.setScreenOrientationOverride` by
    @​Delta456 in https://github.com/SeleniumHQ/selenium/pull/16705
    * [rb] add synchronization and error handling for socket interactions by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16487
    * [rb] mark low level bidi implementation as private api by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16475
    * [rb] ensure driver process is always stopped by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/15635
    * [rb] create user-friendly method for enabling bidi by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/14284
    * [dotnet] [bidi] Added missing Script.RemoteReference LocaclValue type
    by @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16717
    * [dotnet] Standardize `IEquatable<T>` implementations across types
    overriding Equals by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/16665
    * [dotnet] Fix nullability warnings in `WebDriver` by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/16662
    * [py] Don't compare object identity in conftest by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16723
    * #​16720 avoid failing because of temporary Chrome internal files by
    @​asolntsev in https://github.com/SeleniumHQ/selenium/pull/16722
    * [rb] Add force encoding to remove warnings caused by json 3.0 by
    @​aguspe in https://github.com/SeleniumHQ/selenium/pull/16728
    * [py] Remove deprecated FTP proxy support by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16721
    * [py] Bump ruff and mypy versions by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16737
    * Create target directories before copying file by @​MohabMohie in
    https://github.com/SeleniumHQ/selenium/pull/16739
    * [bazel+closure]: Vendor the version of closure library we use by
    @​shs96c in https://github.com/SeleniumHQ/selenium/pull/16742
    * [closure] Fix failing `//javascript/atoms:test-*` targets by @​shs96c
    in https://github.com/SeleniumHQ/selenium/pull/16749
    * Avoid sleep in tests by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16713
    * [bazel] Bump `rules_closure` and google closure libary to latest
    release by @​shs96c in https://github.com/SeleniumHQ/selenium/pull/16755
    * [refactor] call WebDriverException constructor instead of using
    reflection by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16763
    * [build] Pin Browsers in Bazel by default by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16743
    * [build] build selenium manager for tests by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16736
    * [refactor] replace JUnit assertions by AssertJ by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16765
    * [py] Add LocalWebDriver base class by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16730
    * Fix bug in FileHandler: it always failed on MacOS by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16771
    * [java] add missing bazel artifacts by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16773
     ... (truncated)
    
    ## 4.39.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at trunk -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [atoms] fix text node children are always considered as displayed
    #​16284 by @​joerg1985 in
    https://github.com/SeleniumHQ/selenium/pull/16329
    * [grid] Enhance UI with theme integration and improved status
    indicators by @​VietND96 in
    https://github.com/SeleniumHQ/selenium/pull/16512
    * [py][bidi]: add emulation command - `set_locale_override` by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16504
    * [py][bidi]: add emulation command `set_scripting_enabled` by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16513
    * [py] Update docstrings to google pydoc format by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16511
    * [java][BiDi] implement `browsingContext.downloadEnd` event by
    @​Delta456 in https://github.com/SeleniumHQ/selenium/pull/16347
    * Fix typo and minor formatting changes in README.md by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16523
    * [py] Update docstrings (remove reST leftovers and resolve D200) by
    @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/16525
    * [py] Fix docstring formatting and apply ruff linting rules by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16527
    * [py] Fix Ruff D417 warnings in docstrings by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16535
    * [py] Fix ruff D415 warnings in docstrings by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16536
    * [py][bidi]: add `set_screen_orientation_override` command in Emulation
    by @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16522
    * [py] Fix D205 ruff warnings for docstrings and add type hints by
    @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/16537
    * [py][bidi]: add `set_download_behavior` command by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16556
    * [py] Bump pytest and dev dependencies by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16572
    * [bazel] Move `rules_rust` to `bzlmod` by @​shs96c in
    https://github.com/SeleniumHQ/selenium/pull/16566
    * [ci] Make a PR for updating mirror file instead of pushing directly to
    trunk by @​bonigarcia in
    https://github.com/SeleniumHQ/selenium/pull/16579
    * [ci] Update mirror info (2025-11-11T15:26:46Z) by
    @​github-actions[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16578
    * [ci] Revert latest changes related to the mirror workflow by
    @​bonigarcia in https://github.com/SeleniumHQ/selenium/pull/16580
    * [java]: refactor request interception tests and handle CORS by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16585
    * [py][bidi]: enable download event tests for firefox by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16587
    * [py] Fix more type annotations by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16551
    * [java][BiDi] implement `emulation.setTimezoneOverride` by @​Delta456
    in https://github.com/SeleniumHQ/selenium/pull/16530
    * [grid] Minimum Docker API 1.44 for Docker Engine v29+ in Dynamic Grid
    by @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/16591
    * Show file modification time by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16589
    * [py][bidi]: add emulation command `set_user_agent_override` by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16595
    * [grid] Improve Docker client for Dynamic Grid by @​VietND96 in
    https://github.com/SeleniumHQ/selenium/pull/16596
    * [py]: reuse driver in case of bidi tests by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16597
    * [grid] Improve browser container labels and naming in Dynamic Grid by
    @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/16599
    * [build] Upgrade rules_dotnet to 0.20.5 by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16592
    * [dotnet] [bidi] Simplify namespace for communications by @​nvborisenko
    in https://github.com/SeleniumHQ/selenium/pull/16602
    * [py] Improve type hints with union syntax and native types by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16590
    * [py] Use double quotes in generate.py by @​Delta456 in
    https://github.com/SeleniumHQ/selenium/pull/16607
    * [ci] Use pagination in mirror workflow to get all Selenium releases by
    @​bonigarcia in https://github.com/SeleniumHQ/selenium/pull/16605
    * [dotnet] Generate atoms statically by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16608
    * [nodejs] Update dev dependencies to fix vulnerabilities by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/16610
    * [java][BiDi] emulation: allow passing null to GeolocationOverride by
    @​Delta456 in https://github.com/SeleniumHQ/selenium/pull/16594
    * [grid] Update container label `compose.oneoff` in Dynamic Grid by
    @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/16613
     ... (truncated)
    
    ## 4.38.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at trunk -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [dotnet] [bidi] Avoid using JsonInclude attribute to include optional
    property for DTO by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16413
    * [rb] Bump prism to 1.6.0 by @​Earlopain in
    https://github.com/SeleniumHQ/selenium/pull/16450
    * [java] JSpecify annotations for `ExecuteMethod` by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/16464
    * [rb] Fix Network issue by removing nil values on network requests by
    @​aguspe in https://github.com/SeleniumHQ/selenium/pull/16442
    * [py] Replaced :param: and :args: from docstrings by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16469
    * [java] JSpecify annotations for `org.openqa.selenium.federatedcredent…
    by @​mk868 in https://github.com/SeleniumHQ/selenium/pull/16461
    * [java] JSpecify annotations for `org.openqa.selenium.interactions` by
    @​mk868 in https://github.com/SeleniumHQ/selenium/pull/16462
    * [java][rb] Remove cruft from old Travis CI environment by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/16473
    * [java] JSpecify annotations for `org.openqa.selenium.net` by @​mk868
    in https://github.com/SeleniumHQ/selenium/pull/16463
    * [rb] remove deprecated classes for previous implementation of log han…
    by @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16474
    * [build] minimize number of ruby targets run with bidi by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16477
    * [java] JSpecify annotations for `Credential` and `MBean` by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/16481
    * [java] JSpecify annotations for `ScriptKey` and `UnpinnedScriptKey` by
    @​mk868 in https://github.com/SeleniumHQ/selenium/pull/16483
    * [java] JSpecify annotations for `FileDetector` by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/16482
    * [java] JSpecify annotations for `ExpectedCondition` by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/16489
    * [java] JSpecify annotations for `Response` `SessionId` `HttpSessionId`
    by @​mk868 in https://github.com/SeleniumHQ/selenium/pull/16490
    * [rb][build] improve ruby local_dev generation by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16495
    * [build] removing test_tag_filter tag that isn't being used anywhere by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16496
    * [rb][build] disable dev shm for Chrome and Edge on RBE by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16497
    * [rb] update syntax with rspec linter by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16498
    * [java][bidi]: add test for `onHistoryUpdated` event by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16293
    * [py] Bump version of ruff formatter/linter by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16502
    * [rust] Fixe Edge version test by @​bonigarcia in
    https://github.com/SeleniumHQ/selenium/pull/16501
    * [py][bidi]: add `set_timezone_override` command in emulation by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16500
    * [py] Cleanup and convert more doctrings to google-style by
    @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/16503
    * [build] fix update-documentation workflow by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16505
    * fix workflows for updating documentation from stage release by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16506
    
    </details>
    
    **Full Changelog**:
    https://github.com/SeleniumHQ/selenium/compare/selenium-4.37.0...selenium-4.38.0
    
    ## 4.37.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at trunk -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [py] Re-add defaults for Chromium kwargs by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16372
    * Splitting stress tests by @​diemol in
    https://github.com/SeleniumHQ/selenium/pull/16374
    * [rb] Update Chrome/Edge args for test environment by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16376
    * [dotnet] [bidi] Emulation module by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16380
    * [py] Remove old test xfail markers from Travis CI by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16377
    * [dotnet] [bidi] Implement browsing context download events by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16382
    * [dotnet] [bidi] Support browser SetDownloadBehaviour command by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16383
    * [dotnet] [bidi] Support network SetExtraHeaders command by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16384
    * [py][build] Python CI - add unit test job and windows integration
    tests to GH runners by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16362
    * [java] Linux ARM "os.arch" system property is "aarch64" by @​mkurz in
    https://github.com/SeleniumHQ/selenium/pull/16381
    * [dotnet] [bidi] AOT safe enums serialization by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16386
    * [dotnet] Handle negative zero BiDi response by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/15898
    * [dotnet] Move JSON converter attributes from centralized options into
    their respective types by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/16393
    * [py] Fix Selenium Manager tests on Windows by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16391
    * [py] Fix chromedriver/msedgedriver service tests by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16395
    * [dotnet] [bidi] Modules as extensions by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16392
    * [dotnet] [bidi] Provide type info immediately when serializing by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16397
    * [bidi] [dotnet] Use events JsonTypeInfo for deserialization by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16402
    * [dotnet] Replace lazy caching mechanism in BiDi's constructor with
    simple initialization by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/16399
    * [py][build] Re-add Windows to CI workflows by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16396
    * [dotnet] Help more .NETFramework projects to copy SM binaries to
    output by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16406
    * [dotnet] [bidi] Specific result type for any command by @​nvborisenko
    in https://github.com/SeleniumHQ/selenium/pull/16405
    * [dotnet] [bidi] Deserialize message fast instead of defer it by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16403
    * [dotnet] [bidi] Remove IEnumerable of command results by @​nvborisenko
    in https://github.com/SeleniumHQ/selenium/pull/16219
    * [dotnet] Remove obsoleted FtpProxy by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16411
    * [py] Configure WebSocket timeout and wait interval via ClientConfig by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16248
    * [java] Rescuing the remote cause for session creation errors by
    @​diemol in https://github.com/SeleniumHQ/selenium/pull/16418
    * [py] Add test for BiDi request handlers with classic navigation by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16421
    * [java] NullAway added by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/16416
    * [java] feat: Add native Java 11 HTTP client methods to HttpClient
    interface by @​manuelsblanco in
    https://github.com/SeleniumHQ/selenium/pull/16412
    * [py] Raise NotImplementedError when deleting downloads in driver
    subclass by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16423
    * [java] refactor(remote/command): Merge overload's business logic by
    @​nnnnoel in https://github.com/SeleniumHQ/selenium/pull/14469
    * [py] Fix default rpId in virtual authenticator by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16428
    * make augmentation of HasBiDi/HasDevTools lazy-loaded by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16338
    * [py] Update docstrings style by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16427
    * [py] Support Python 3.14 and drop Python 3.9 by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16342
    * Removing FF guard for canListenToDownloadWillBeginEvent by @​diemol in
    https://github.com/SeleniumHQ/selenium/pull/16439
    * Adapting the browser_protocol file fetching to the file structure
    change. by @​diemol in https://github.com/SeleniumHQ/selenium/pull/16440
     ... (truncated)
    
    ## 4.36.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at trunk -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [py]: close ipv6 port in case of error by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16165
    * [docs] Update issue label in CONTRIBUTING.md by @​pallavigitwork in
    https://github.com/SeleniumHQ/selenium/pull/16169
    * [py][docs]: update dead API docs link to API reference in `index.rst`
    by @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16170
    * [grid] close the HttpClient after the session is gone by @​joerg1985
    in https://github.com/SeleniumHQ/selenium/pull/16182
    * [py] Update docstring and comments in keys.py by @​Aidoni0797 in
    https://github.com/SeleniumHQ/selenium/pull/16187
    * [dotnet] [bidi] Simplify type naming of internal command parameters by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16188
    * [py] Fix formatting by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16189
    * [dotnet] [bidi] Support WebExtension module by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15850
    * [rb][BiDi] Create browser module, added user context related methods
    by @​aguspe in https://github.com/SeleniumHQ/selenium/pull/15371
    * [docs] Update bug report section in CONTRIBUTING.md by
    @​pallavigitwork in https://github.com/SeleniumHQ/selenium/pull/16191
    * [dotnet] Adding flag to enable SafariDriver logging. by @​diemol in
    https://github.com/SeleniumHQ/selenium/pull/16196
    * [java] extend the scope of the properties of the HttpCommandExecutor
    class by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16186
    * [dotnet] [bidi] Serialize base64 encoded string directly to bytes by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16203
    * [dotnet] [bidi] Make cookie expiry as TimeSpan by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16204
    * [grid] Improve readTimeout in handle session between Router and Node
    by @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/16163
    * [py] Fix type annotation error and raise clearer error message by
    @​Paresh-0007 in https://github.com/SeleniumHQ/selenium/pull/16174
    * [java] Unifying select class by @​vicky-iv in
    https://github.com/SeleniumHQ/selenium/pull/16220
    * [rust] Update dependency rules_cc to v0.2.0 by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16198
    * [js] Update testing-library monorepo by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16173
    * [js] Update dependency tmp to ^0.2.5 by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16172
    * [dotnet] Update dependency System.Text.Json to 8.0.6 by
    @​renovate[bot] in https://github.com/SeleniumHQ/selenium/pull/16171
    * [js] Update dependency react-router-dom to v6.30.1 by @​renovate[bot]
    in https://github.com/SeleniumHQ/selenium/pull/16076
    * [js] Update material-ui monorepo to v5.18.0 by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16062
    * [js] Update dependency ws to ^8.18.3 by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16009
    * [js] Update react monorepo by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/15949
    * [java] Update dependency net.bytebuddy:byte-buddy to v1.17.7 by
    @​renovate[bot] in https://github.com/SeleniumHQ/selenium/pull/16237
    * [py] Update dependency charset-normalizer to v3.4.3 by @​renovate[bot]
    in https://github.com/SeleniumHQ/selenium/pull/16239
    * [py] Update dependency cryptography to v45.0.6 by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16240
    * Revert "[py] Update dependency charset-normalizer to v3.4.3" by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16242
    * Revert "[py] Update dependency cryptography to v45.0.6" by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/16243
    * [py] Bump dependencies for dev and fix script by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16244
    * [dotnet] Help old .net framework copy selenium manager to output by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16228
    * [java] Add hooks around getScreenshotAs in WebDriverListener #​16232
    by @​giulong in https://github.com/SeleniumHQ/selenium/pull/16233
    * [py][bidi]: enable `history_updated` event test by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16236
    * [py] Bump ruff version for linting/formatting by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16254
    * [py][bidi]: use bidi `navigate` command in network tests by @​navin772
    in https://github.com/SeleniumHQ/selenium/pull/16251
    * [dotnet] Fix find port for IPv4 only environments by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16216
    * [dotnet] [bidi] Adjust cookie expiry type according spec (unix
    seconds) by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16218
     ... (truncated)
    
    ## 4.35.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at 1c58e5028bc5eaa94b12b856c2d4a87efa5363f5 -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [dotnet] [bidi] Get tree command returns GetTreeResult object by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/15978
    * [dotnet] [bidi] Initialize internal modules without Lazy by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/15979
    * [py] Bump dependencies for building distribution wheel by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/15977
    * bump zip version 2.6.1 -> 4.2.0 by @​MRTamalampudi in
    https://github.com/SeleniumHQ/selenium/pull/15980
    * [py][bidi]: add note for `enable_webextensions = False` by @​navin772
    in https://github.com/SeleniumHQ/selenium/pull/15981
    * [py][bidi]: add high level API for script module - `pin`, `unpin` and
    `execute` by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15936
    * [py][java][rb][ci]: use pinned browsers in CI by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15987
    * [java] Remove deprecated AppCacheStatus enum from the HTML5 package by
    @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/15973
    * [java] Feat 14291/jspecify nullable annotation edge driver service by
    @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/15972
    * [java] Fix Unicode value for OPTION key in Keys enum by @​iampopovich
    in https://github.com/SeleniumHQ/selenium/pull/15966
    * [dotnet][java][js][py][rb][rust] Update rules_jvm_external digest to
    aca619b by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/15951
    * [java] Removing old stream collectors required by Java 8 by @​zodac in
    https://github.com/SeleniumHQ/selenium/pull/15523
    * [java] Use static Patterns for regex-matching by @​zodac in
    https://github.com/SeleniumHQ/selenium/pull/15499
    * [java] Point made as immutable by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/15511
    * [java] Feat 14291/jspecify nullable annotation chrome driver såervice
    by @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/15998
    * [py] Bump dev dependencies by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16002
    * [grid] Add "URI" to the list of sort-by choices on Overview UI by
    @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/16004
    * [java] Add @​Nullable annotations to Firefox and Gecko driver service
    by @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/15999
    * [java] Add JSpecify nullable annotations to SafariDriverService
    parameters by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16000
    * [java] Add @​Nullable annotations to InternetExplorerDriverService
    parameters by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16001
    * use generics for AbstractFindByBuilder to avoid excessive casting by
    @​asolntsev in https://github.com/SeleniumHQ/selenium/pull/15526
    * [js] Update dependency @​emotion/styled to v11.14.1 by @​renovate[bot]
    in https://github.com/SeleniumHQ/selenium/pull/15997
    * [rust] Update which from 7.0.3 to 8.0.0 by @​musicinmybrain in
    https://github.com/SeleniumHQ/selenium/pull/15965
    * Fix various typos by @​noritaka1166 in
    https://github.com/SeleniumHQ/selenium/pull/16012
    * [java] JSpecify annotations for By locators by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/14372
    * Fix email address in .mailmap by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16017
    * Fix typos in javascript & rb by @​noritaka1166 in
    https://github.com/SeleniumHQ/selenium/pull/16019
    * [java] JSpecify annotations for capabilities by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/14397
    * Fix various typos in comments by @​noritaka1166 in
    https://github.com/SeleniumHQ/selenium/pull/16022
    * [dotnet] Fix typos by @​noritaka1166 in
    https://github.com/SeleniumHQ/selenium/pull/16032
    * [dotnet] [bidi] Add UnhandledPromptBehavior option to create User
    Context by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16034
    * [py] Fix path in unit test so it works cross-platform by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/16033
    * [py][bidi]: implement bidi module - emulation by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15819
    * [py] Fix API doc generation script and include BiDi Emulation docs by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16037
    * [py] Allow free_port() to bind to IPv6 if IPv4 is unavailable by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16003
    * [build] Update base URL for Edge web driver by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16057
    * [rust] Update base URL for Edge web driver by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16056
     ... (truncated)
    
    ## 4.34.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at 2a4c61c498207b17cdb2f5f987c7c71dca146c2d -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [ci] Clear warning from Grid UI component tests by @​VietND96 in
    https://github.com/SeleniumHQ/selenium/pull/15783
    * [py] Fix pytest_ignore_collect hook to respect --ignore by @​mgorny in
    https://github.com/SeleniumHQ/selenium/pull/15787
    * [py] Increase timeout in devtools test by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15793
    * [py] Upgrade type hints by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15784
    * [dotnet] [bidi] Add AcceptInsecureCerts and Proxy options when create
    new user context by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15795
    * [grid] Silent fail on invalid log level by @​Oxilod in
    https://github.com/SeleniumHQ/selenium/pull/15796
    * Bump setup-bazel action by @​p0deje in
    https://github.com/SeleniumHQ/selenium/pull/15802
    * Don't silence stderr in format.sh by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15804
    * [dotnet] [bidi] Declare allowed nullable objects in constructors type
    by @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/15809
    * Fix type error for attribute in remote_connection.py by @​Bradltr95 in
    https://github.com/SeleniumHQ/selenium/pull/15810
    * [py] Lint Python with ruff by @​p0deje in
    https://github.com/SeleniumHQ/selenium/pull/15811
    * fixed error in selenium/webdriver/common/bidi/common.py:19 by
    @​pallavigitwork in https://github.com/SeleniumHQ/selenium/pull/15814
    * [py] Fix import for type hint by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15817
    * [py] Bump ruff version by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15818
    * [dotnet] [bidi] Simplify modules namespace for end users (breaking
    change) by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15820
    * [dotnet] Remove unnecessary stylecop files by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15824
    * [py] Lint and format all python files by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15828
    * [py][bidi]: add `enable_webextensions` option for chromium-based
    browsers by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15794
    * [py] Auto-generate Python API docs from code by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15822
    * [py] Fix python API docs publishing at readthedocs by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15832
    * Change flag for Chrome/Edge headless mode in tests by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15831
    * [py] Cleanup tox config by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15833
    * [rb] Add support for beta chrome by @​aguspe in
    https://github.com/SeleniumHQ/selenium/pull/15417
    * Revert "[rb] Add support for beta chrome" by @​aguspe in
    https://github.com/SeleniumHQ/selenium/pull/15837
    * [py] Fix: Mypy type annotation errors by @​ShauryaDusht in
    https://github.com/SeleniumHQ/selenium/pull/15841
    * [py] New script to update Python dependencies by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15845
    * fixed errors in browser.py for 15697 by @​pallavigitwork in
    https://github.com/SeleniumHQ/selenium/pull/15847
    * [py][bidi]: implement bidi permissions module by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15830
    * [py] Regeneratee py/docs/source/api.rst by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15856
    * [dotnet] Align CS projects name to understand the editing context by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/15843
    * [py][bidi]: enable edge bidi storage test - `test_get_all_cookies` by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/15859
    * Caching the size/length in loops to slightly improve performance by
    @​LuisOsv in https://github.com/SeleniumHQ/selenium/pull/15852
    * Update exceptions.py by @​adolfoarmas in
    https://github.com/SeleniumHQ/selenium/pull/15862
    * Revert "Update exceptions.py" by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15864
    * [py] Re-apply #​15862 by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15865
    * [py] fix driver_element_finding_tests.py by @​Delta456 in
    https://github.com/SeleniumHQ/selenium/pull/15863
    * [py] Fix another broken test by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15866
     ... (truncated)
    
    ## 4.33.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at 2c6aaad03a575cd93e4f063f91404e3ae66a7470 -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [py] Exclude devtools directory from type checking by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15695
    * [py] Add clean_options fixture and remove all Python tests from
    .skipped-tests by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15696
    * [java][bidi]: enable tests for storage module for edge by @​navin772
    in https://github.com/SeleniumHQ/selenium/pull/15667
    * [py][bidi]: add bidi storage module by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15669
    * [build] allow GitHub Actions runner to use 4GB for JVM Heap by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/15692
    * update old freenode channel link to libera by @​t7ru in
    https://github.com/SeleniumHQ/selenium/pull/15698
    * fixing mypy error from #​15693 by @​bandophahita in
    https://github.com/SeleniumHQ/selenium/pull/15705
    * [java] Removing deprecated items in Require.java by @​diemol in
    https://github.com/SeleniumHQ/selenium/pull/15711
    * [java] Removing RemoteStatus as it was deprecated. by @​diemol in
    https://github.com/SeleniumHQ/selenium/pull/15712
    * [rb] move all guard and zipper tests to unit tests by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/15717
    * [rust] Replace WMIC commands (deprecated) by WinAPI in Windows by
    @​bonigarcia in https://github.com/SeleniumHQ/selenium/pull/15363
    * [py][BiDi] use constant for LogLevel by @​Delta456 in
    https://github.com/SeleniumHQ/selenium/pull/15677
    * Let firefox choose the bidi port by default by @​tomhughes in
    https://github.com/SeleniumHQ/selenium/pull/15727
    * [rb] Upgrade to Ruby 3.2 by @​p0deje in
    https://github.com/SeleniumHQ/selenium/pull/15714
    * [py] Missing Headers Assignment in Network Class’s _on_request() by
    @​shbenzer in https://github.com/SeleniumHQ/selenium/pull/15736
    * [py] correct type annotations of default-None params by
    @​DeflateAwning in https://github.com/SeleniumHQ/selenium/pull/15341
    * [py] Add missing 'id' property to ShadowRoot class by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15739
    * [py] Bump Python package requirements to latest versions by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/15731
    * [py] Use ruff for linting and code formatting by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15746
    * [py]: return `message` as part of exception in `execute` method by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/15751
    * [py][tests]: check for .txt file in remote download test by @​navin772
    in https://github.com/SeleniumHQ/selenium/pull/15758
    * [java] Removing deprecated `setScriptTimeout` and `pageLoadTimeout`.
    by @​diemol in https://github.com/SeleniumHQ/selenium/pull/15764
    * [py][bidi]: add bidi webExtension module by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15749
    * [py] Better error for downloads on local webdrivers by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15756
    * [py] Add missing modules to python API docs by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15779
    * [ci] Workflow for Grid UI component tests by @​VietND96 in
    https://github.com/SeleniumHQ/selenium/pull/15778
    * [grid] UI Sessions capability fields to display as additional columns
    by @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/15759
    * [grid] UI Overview is able to see live preview per Node by @​VietND96
    in https://github.com/SeleniumHQ/selenium/pull/15777
    
    ## New Contributors
    * @​t7ru made their first contribution in
    https://github.com/SeleniumHQ/selenium/pull/15698
    * @​tomhughes made their first contribution in
    https://github.com/SeleniumHQ/selenium/pull/15727
    * @​DeflateAwning made their first contribution in
    https://github.com/SeleniumHQ/selenium/pull/15341
    
    </details>
    
    **Full Changelog**:
    https://github.com/SeleniumHQ/selenium/compare/selenium-4.32.0...selenium-4.33.0
    
    ## 4.32.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at d17c8aa95092dc25ae64f12e7abdc844cf3503f0 -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [py] Fix test args for --headless and --bidi by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15567
    * [py] Only skip WebKit tests on Windows by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15470
    * [dotnet] [bidi] Revisit some core functionality to deserialize without
    intermediate `JsonElement` allocation by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15575
    * [py] Fix broken test for chromedriver logging by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15579
    * [py] Fix test for w3c touch pointer properties by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15580
    * [py] Fix FedCM tests leaking state by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15583
    * [dotnet] [bidi] Address BiDi's JSON converter AOT warnings by
    @​RenderMichael in https://github.com/SeleniumHQ/selenium/pull/15390
    * [dotnet] [bidi] Added missing GenericLogEntry log entry type in Script
    module by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15591
    * [grid] Ignored options when they are prefixed, safari specif as well
    by @​diemol in https://github.com/SeleniumHQ/selenium/pull/15574
    * [py] Remove broken logo from Sphinx generated API docs by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/15597
    * [py] Fix PyTest configuration for WPEWebKit by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15602
    * [py] Fix failing test for Edge logging by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15605
    * [rb] Add PrintOptions Implementation for Ruby WebDriver by @​yvsvarma
    in https://github.com/SeleniumHQ/selenium/pull/15158
    * [py] BiDi Network implementation of Intercepts and Auth in Python by
    @​shbenzer in https://github.com/SeleniumHQ/selenium/pull/14592
    * [py] Use XWayland for internal Python Firefox tests by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15601
    * [py] Use mock.patch for environment variables in tests by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/15607
    * [ruby] fix lint for print_options.rb by @​Delta456 in
    https://github.com/SeleniumHQ/selenium/pull/15608
    * [py] Configure readthedocs publishing for Python API docs by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/15614
    * [py] Fix select being able to select options hidden by css rules by
    @​FFederi in https://github.com/SeleniumHQ/selenium/pull/15135
    * [py][bidi]: Implement BiDi browser module by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15616
    * [dotnet] [bidi] Combine network interception to apply rules (breaking
    change) by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15603
    * [dotnet] [bidi] Add strongly-typed `LocalValue.ConvertFrom` overloads
    by @​RenderMichael in https://github.com/SeleniumHQ/selenium/pull/15532
    * [py] Add missing modules to Python API docs by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15624
    * [dotnet] [bidi] Do not throw when CallFunction or Evaluate return
    exceptional result (breaking change) by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/15521
    * [py] Skip bidi tests on browsers that don't support bidi by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/15625
    * [py] complete
    `test_should_throw_an_exception_if_an_alert_has_not_been_dealt_with_and_dismiss_the_alert`
    by @​Delta456 in https://github.com/SeleniumHQ/selenium/pull/15559
    * [py] Remove unused xfail on chrome/edge service tests by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/15637
    * [py] Adjust xfail markers for window size/position tests by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/15638
    * [py] Call service.stop() when session can't be started by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/15636
    * [dotnet] [bidi] Reuse memory when receiving websocket messages by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/15640
    * [py] Remove logging API for non-Chromium browsers by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15641
    * [py] Raise TypeError when creating webdriver.Remote() without options
    by @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/15619
    * [py] Upgrade dependencies for mypy tox environment by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15642
    * [py] Fix Remote Firefox tests on Linux/Wayland by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15648
    * [dotnet] Enhance Selenium Manager platform detection by @​nvborisenko
    in https://github.com/SeleniumHQ/selenium/pull/15649
    * [dotnet] Use namespace file scoped by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15651
    * [py] Fix flaky WebDriverWait tests by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15650
     ... (truncated)
    
    Commits viewable in [compare
    view](https://github.com/SeleniumHQ/selenium/compare/selenium-4.31.0...selenium-4.41.0).
    </details>
    
    Updated [Selenium.WebDriver](https://github.com/SeleniumHQ/selenium)
    from 4.31.0 to 4.41.0.
    
    <details>
    <summary>Release notes</summary>
    
    _Sourced from [Selenium.WebDriver's
    releases](https://github.com/SeleniumHQ/selenium/releases)._
    
    ## 4.41.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    <!-- Release notes generated using configuration in .github/release.yml
    at selenium-4.41.0 -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [py] Remove type stub packages from runtime dependencies by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16945
    * Canonical approach to supporting AI agent directions by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16735
    * [build] Pre-release workflow improvements by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16946
    * [build] Prevent nightly releases during release window by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16948
    * [build] Fix Bazel NuGet push implementation by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16950
    * [build] Release workflow improvements by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16947
    * [build] Fix Bazel JSDocs implementation by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16949
    * [build] Create config files from environment variables for publishing
    by @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16951
    * [js] create task to update dependencies by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16942
    * [build] Java release improvements and build verification tasks by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16952
    * [py] integrate mypy type checking with Bazel by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16958
    * [build] Migrate workflows to use centralized bazel.yml by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16955
    * [dotnet] [bidi] Simplify context aware command options by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16954
    * [build] simplify release.yml: remove draft, build once during publish
    by @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16960
    * [dotnet] [bidi] AOT safe json converter for `Input.Origin` class by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16962
    * [dotnet] [bidi] AOT safe json converter for `OptionalConverter` by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16963
    * [dotnet] [bidi] Null guard for event handlers by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16967
    * [java] Improve error message for died grid by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16938
    * [build] combine pre-release dependency updates by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16973
    * [rb] remove stored atoms these get generated by build by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16971
    * [dotnet] [bidi] Unignore some internal tests by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16968
    * [build] run ruff on python files outside py directory by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16957
    * [py] Fix return type hint for `alert_is_present` by @​nemowang2003 in
    https://github.com/SeleniumHQ/selenium/pull/16975
    * Replace hardcoded bazel-selenium references with dynamic path
    resolution by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16976
    * No More CrazyFun! by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16972
    * [build] Remove update_gh_pages in favor of CI workflow by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16977
    * [build] Remove legacy rake helpers and unused code by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16978
    * [py] make bazel test target names consistent with other languages by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16969
    * [dotnet] [bidi] Fix namespace for Permissions module by @​nvborisenko
    in https://github.com/SeleniumHQ/selenium/pull/16981
    * [dotnet] [bidi] Hide Broker as internal implementation by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16982
    * [dotnet] [bidi] Refactor BiDi module initialization to pass BiDi
    explicitly by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16983
    * [build] Add DocFX updater script by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16980
    * [build] add reusable commit-changes.yml workflow by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16965
    * [java] fix JSON parsing of numbers with exponent by @​joerg1985 in
    https://github.com/SeleniumHQ/selenium/pull/16961
    * [build] Skip macOS-only archive rules on unsupported platforms by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16985
    * [build] Split Rakefile into per-language task files by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16979
    * Implement fast bazel target lookup with index caching by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16974
    * [build] Remove git.add() calls from rake tasks by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16994
    * [js] Add eslint binary target for selenium-webdriver by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16992
     ... (truncated)
    
    ## 4.40.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images…
    PhilipWoulfe added a commit to PhilipWoulfe/F1Competition that referenced this pull request Mar 16, 2026
    Updated [Selenium.WebDriver](https://github.com/SeleniumHQ/selenium)
    from 4.31.0 to 4.41.0.
    
    <details>
    <summary>Release notes</summary>
    
    _Sourced from [Selenium.WebDriver's
    releases](https://github.com/SeleniumHQ/selenium/releases)._
    
    ## 4.41.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    <!-- Release notes generated using configuration in .github/release.yml
    at selenium-4.41.0 -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [py] Remove type stub packages from runtime dependencies by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16945
    * Canonical approach to supporting AI agent directions by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16735
    * [build] Pre-release workflow improvements by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16946
    * [build] Prevent nightly releases during release window by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16948
    * [build] Fix Bazel NuGet push implementation by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16950
    * [build] Release workflow improvements by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16947
    * [build] Fix Bazel JSDocs implementation by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16949
    * [build] Create config files from environment variables for publishing
    by @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16951
    * [js] create task to update dependencies by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16942
    * [build] Java release improvements and build verification tasks by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16952
    * [py] integrate mypy type checking with Bazel by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16958
    * [build] Migrate workflows to use centralized bazel.yml by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16955
    * [dotnet] [bidi] Simplify context aware command options by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16954
    * [build] simplify release.yml: remove draft, build once during publish
    by @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16960
    * [dotnet] [bidi] AOT safe json converter for `Input.Origin` class by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16962
    * [dotnet] [bidi] AOT safe json converter for `OptionalConverter` by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16963
    * [dotnet] [bidi] Null guard for event handlers by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16967
    * [java] Improve error message for died grid by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16938
    * [build] combine pre-release dependency updates by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16973
    * [rb] remove stored atoms these get generated by build by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16971
    * [dotnet] [bidi] Unignore some internal tests by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16968
    * [build] run ruff on python files outside py directory by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16957
    * [py] Fix return type hint for `alert_is_present` by @​nemowang2003 in
    https://github.com/SeleniumHQ/selenium/pull/16975
    * Replace hardcoded bazel-selenium references with dynamic path
    resolution by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16976
    * No More CrazyFun! by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16972
    * [build] Remove update_gh_pages in favor of CI workflow by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16977
    * [build] Remove legacy rake helpers and unused code by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16978
    * [py] make bazel test target names consistent with other languages by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16969
    * [dotnet] [bidi] Fix namespace for Permissions module by @​nvborisenko
    in https://github.com/SeleniumHQ/selenium/pull/16981
    * [dotnet] [bidi] Hide Broker as internal implementation by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16982
    * [dotnet] [bidi] Refactor BiDi module initialization to pass BiDi
    explicitly by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16983
    * [build] Add DocFX updater script by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16980
    * [build] add reusable commit-changes.yml workflow by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16965
    * [java] fix JSON parsing of numbers with exponent by @​joerg1985 in
    https://github.com/SeleniumHQ/selenium/pull/16961
    * [build] Skip macOS-only archive rules on unsupported platforms by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16985
    * [build] Split Rakefile into per-language task files by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16979
    * Implement fast bazel target lookup with index caching by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16974
    * [build] Remove git.add() calls from rake tasks by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16994
    * [js] Add eslint binary target for selenium-webdriver by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/16992
     ... (truncated)
    
    ## 4.40.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at trunk -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [dotnet] Modernize `EnvironmentManager`, standardize assembly teardown
    by @​RenderMichael in https://github.com/SeleniumHQ/selenium/pull/15551
    * [java] Refactor tests by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16684
    * [ci]: bump cargo lockfile by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16698
    * [java][BiDi] change emulation commands return type to void by
    @​Delta456 in https://github.com/SeleniumHQ/selenium/pull/16699
    * [java] simplify strings processing by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/15309
    * Fix few more flaky ruby tests by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16695
    * [bazel] Switch to custom `closure_js_deps` rule by @​shs96c in
    https://github.com/SeleniumHQ/selenium/pull/16571
    * [dotnet] [bidi] Support SetScreenSettingsOverrideAsync method in
    Emulation module by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16704
    * [dotnet] Modernize code patterns in test suites by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/16701
    * use proper AssertJ asserts that generate a useful error message by
    @​asolntsev in https://github.com/SeleniumHQ/selenium/pull/16707
    * fix Java language level in IDEA by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16708
    * [py] Properly verify Selenium Manager exists by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16711
    * fix flaky Ruby test `element_spec.rb` by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16709
    * [java][BiDi] implement `emulation.setScreenOrientationOverride` by
    @​Delta456 in https://github.com/SeleniumHQ/selenium/pull/16705
    * [rb] add synchronization and error handling for socket interactions by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16487
    * [rb] mark low level bidi implementation as private api by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16475
    * [rb] ensure driver process is always stopped by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/15635
    * [rb] create user-friendly method for enabling bidi by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/14284
    * [dotnet] [bidi] Added missing Script.RemoteReference LocaclValue type
    by @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16717
    * [dotnet] Standardize `IEquatable<T>` implementations across types
    overriding Equals by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/16665
    * [dotnet] Fix nullability warnings in `WebDriver` by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/16662
    * [py] Don't compare object identity in conftest by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16723
    * #​16720 avoid failing because of temporary Chrome internal files by
    @​asolntsev in https://github.com/SeleniumHQ/selenium/pull/16722
    * [rb] Add force encoding to remove warnings caused by json 3.0 by
    @​aguspe in https://github.com/SeleniumHQ/selenium/pull/16728
    * [py] Remove deprecated FTP proxy support by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16721
    * [py] Bump ruff and mypy versions by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16737
    * Create target directories before copying file by @​MohabMohie in
    https://github.com/SeleniumHQ/selenium/pull/16739
    * [bazel+closure]: Vendor the version of closure library we use by
    @​shs96c in https://github.com/SeleniumHQ/selenium/pull/16742
    * [closure] Fix failing `//javascript/atoms:test-*` targets by @​shs96c
    in https://github.com/SeleniumHQ/selenium/pull/16749
    * Avoid sleep in tests by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16713
    * [bazel] Bump `rules_closure` and google closure libary to latest
    release by @​shs96c in https://github.com/SeleniumHQ/selenium/pull/16755
    * [refactor] call WebDriverException constructor instead of using
    reflection by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16763
    * [build] Pin Browsers in Bazel by default by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16743
    * [build] build selenium manager for tests by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16736
    * [refactor] replace JUnit assertions by AssertJ by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16765
    * [py] Add LocalWebDriver base class by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16730
    * Fix bug in FileHandler: it always failed on MacOS by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16771
    * [java] add missing bazel artifacts by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16773
     ... (truncated)
    
    ## 4.39.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at trunk -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [atoms] fix text node children are always considered as displayed
    #​16284 by @​joerg1985 in
    https://github.com/SeleniumHQ/selenium/pull/16329
    * [grid] Enhance UI with theme integration and improved status
    indicators by @​VietND96 in
    https://github.com/SeleniumHQ/selenium/pull/16512
    * [py][bidi]: add emulation command - `set_locale_override` by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16504
    * [py][bidi]: add emulation command `set_scripting_enabled` by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16513
    * [py] Update docstrings to google pydoc format by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16511
    * [java][BiDi] implement `browsingContext.downloadEnd` event by
    @​Delta456 in https://github.com/SeleniumHQ/selenium/pull/16347
    * Fix typo and minor formatting changes in README.md by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16523
    * [py] Update docstrings (remove reST leftovers and resolve D200) by
    @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/16525
    * [py] Fix docstring formatting and apply ruff linting rules by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16527
    * [py] Fix Ruff D417 warnings in docstrings by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16535
    * [py] Fix ruff D415 warnings in docstrings by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16536
    * [py][bidi]: add `set_screen_orientation_override` command in Emulation
    by @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16522
    * [py] Fix D205 ruff warnings for docstrings and add type hints by
    @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/16537
    * [py][bidi]: add `set_download_behavior` command by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16556
    * [py] Bump pytest and dev dependencies by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16572
    * [bazel] Move `rules_rust` to `bzlmod` by @​shs96c in
    https://github.com/SeleniumHQ/selenium/pull/16566
    * [ci] Make a PR for updating mirror file instead of pushing directly to
    trunk by @​bonigarcia in
    https://github.com/SeleniumHQ/selenium/pull/16579
    * [ci] Update mirror info (2025-11-11T15:26:46Z) by
    @​github-actions[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16578
    * [ci] Revert latest changes related to the mirror workflow by
    @​bonigarcia in https://github.com/SeleniumHQ/selenium/pull/16580
    * [java]: refactor request interception tests and handle CORS by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16585
    * [py][bidi]: enable download event tests for firefox by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16587
    * [py] Fix more type annotations by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16551
    * [java][BiDi] implement `emulation.setTimezoneOverride` by @​Delta456
    in https://github.com/SeleniumHQ/selenium/pull/16530
    * [grid] Minimum Docker API 1.44 for Docker Engine v29+ in Dynamic Grid
    by @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/16591
    * Show file modification time by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16589
    * [py][bidi]: add emulation command `set_user_agent_override` by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16595
    * [grid] Improve Docker client for Dynamic Grid by @​VietND96 in
    https://github.com/SeleniumHQ/selenium/pull/16596
    * [py]: reuse driver in case of bidi tests by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16597
    * [grid] Improve browser container labels and naming in Dynamic Grid by
    @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/16599
    * [build] Upgrade rules_dotnet to 0.20.5 by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16592
    * [dotnet] [bidi] Simplify namespace for communications by @​nvborisenko
    in https://github.com/SeleniumHQ/selenium/pull/16602
    * [py] Improve type hints with union syntax and native types by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16590
    * [py] Use double quotes in generate.py by @​Delta456 in
    https://github.com/SeleniumHQ/selenium/pull/16607
    * [ci] Use pagination in mirror workflow to get all Selenium releases by
    @​bonigarcia in https://github.com/SeleniumHQ/selenium/pull/16605
    * [dotnet] Generate atoms statically by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16608
    * [nodejs] Update dev dependencies to fix vulnerabilities by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/16610
    * [java][BiDi] emulation: allow passing null to GeolocationOverride by
    @​Delta456 in https://github.com/SeleniumHQ/selenium/pull/16594
    * [grid] Update container label `compose.oneoff` in Dynamic Grid by
    @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/16613
     ... (truncated)
    
    ## 4.38.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at trunk -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [dotnet] [bidi] Avoid using JsonInclude attribute to include optional
    property for DTO by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16413
    * [rb] Bump prism to 1.6.0 by @​Earlopain in
    https://github.com/SeleniumHQ/selenium/pull/16450
    * [java] JSpecify annotations for `ExecuteMethod` by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/16464
    * [rb] Fix Network issue by removing nil values on network requests by
    @​aguspe in https://github.com/SeleniumHQ/selenium/pull/16442
    * [py] Replaced :param: and :args: from docstrings by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16469
    * [java] JSpecify annotations for `org.openqa.selenium.federatedcredent…
    by @​mk868 in https://github.com/SeleniumHQ/selenium/pull/16461
    * [java] JSpecify annotations for `org.openqa.selenium.interactions` by
    @​mk868 in https://github.com/SeleniumHQ/selenium/pull/16462
    * [java][rb] Remove cruft from old Travis CI environment by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/16473
    * [java] JSpecify annotations for `org.openqa.selenium.net` by @​mk868
    in https://github.com/SeleniumHQ/selenium/pull/16463
    * [rb] remove deprecated classes for previous implementation of log han…
    by @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16474
    * [build] minimize number of ruby targets run with bidi by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16477
    * [java] JSpecify annotations for `Credential` and `MBean` by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/16481
    * [java] JSpecify annotations for `ScriptKey` and `UnpinnedScriptKey` by
    @​mk868 in https://github.com/SeleniumHQ/selenium/pull/16483
    * [java] JSpecify annotations for `FileDetector` by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/16482
    * [java] JSpecify annotations for `ExpectedCondition` by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/16489
    * [java] JSpecify annotations for `Response` `SessionId` `HttpSessionId`
    by @​mk868 in https://github.com/SeleniumHQ/selenium/pull/16490
    * [rb][build] improve ruby local_dev generation by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16495
    * [build] removing test_tag_filter tag that isn't being used anywhere by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16496
    * [rb][build] disable dev shm for Chrome and Edge on RBE by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16497
    * [rb] update syntax with rspec linter by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16498
    * [java][bidi]: add test for `onHistoryUpdated` event by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16293
    * [py] Bump version of ruff formatter/linter by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16502
    * [rust] Fixe Edge version test by @​bonigarcia in
    https://github.com/SeleniumHQ/selenium/pull/16501
    * [py][bidi]: add `set_timezone_override` command in emulation by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16500
    * [py] Cleanup and convert more doctrings to google-style by
    @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/16503
    * [build] fix update-documentation workflow by @​titusfortner in
    https://github.com/SeleniumHQ/selenium/pull/16505
    * fix workflows for updating documentation from stage release by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/16506
    
    </details>
    
    **Full Changelog**:
    https://github.com/SeleniumHQ/selenium/compare/selenium-4.37.0...selenium-4.38.0
    
    ## 4.37.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at trunk -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [py] Re-add defaults for Chromium kwargs by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16372
    * Splitting stress tests by @​diemol in
    https://github.com/SeleniumHQ/selenium/pull/16374
    * [rb] Update Chrome/Edge args for test environment by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16376
    * [dotnet] [bidi] Emulation module by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16380
    * [py] Remove old test xfail markers from Travis CI by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16377
    * [dotnet] [bidi] Implement browsing context download events by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16382
    * [dotnet] [bidi] Support browser SetDownloadBehaviour command by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16383
    * [dotnet] [bidi] Support network SetExtraHeaders command by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16384
    * [py][build] Python CI - add unit test job and windows integration
    tests to GH runners by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16362
    * [java] Linux ARM "os.arch" system property is "aarch64" by @​mkurz in
    https://github.com/SeleniumHQ/selenium/pull/16381
    * [dotnet] [bidi] AOT safe enums serialization by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16386
    * [dotnet] Handle negative zero BiDi response by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/15898
    * [dotnet] Move JSON converter attributes from centralized options into
    their respective types by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/16393
    * [py] Fix Selenium Manager tests on Windows by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16391
    * [py] Fix chromedriver/msedgedriver service tests by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16395
    * [dotnet] [bidi] Modules as extensions by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16392
    * [dotnet] [bidi] Provide type info immediately when serializing by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16397
    * [bidi] [dotnet] Use events JsonTypeInfo for deserialization by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16402
    * [dotnet] Replace lazy caching mechanism in BiDi's constructor with
    simple initialization by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/16399
    * [py][build] Re-add Windows to CI workflows by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16396
    * [dotnet] Help more .NETFramework projects to copy SM binaries to
    output by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16406
    * [dotnet] [bidi] Specific result type for any command by @​nvborisenko
    in https://github.com/SeleniumHQ/selenium/pull/16405
    * [dotnet] [bidi] Deserialize message fast instead of defer it by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16403
    * [dotnet] [bidi] Remove IEnumerable of command results by @​nvborisenko
    in https://github.com/SeleniumHQ/selenium/pull/16219
    * [dotnet] Remove obsoleted FtpProxy by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16411
    * [py] Configure WebSocket timeout and wait interval via ClientConfig by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16248
    * [java] Rescuing the remote cause for session creation errors by
    @​diemol in https://github.com/SeleniumHQ/selenium/pull/16418
    * [py] Add test for BiDi request handlers with classic navigation by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16421
    * [java] NullAway added by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/16416
    * [java] feat: Add native Java 11 HTTP client methods to HttpClient
    interface by @​manuelsblanco in
    https://github.com/SeleniumHQ/selenium/pull/16412
    * [py] Raise NotImplementedError when deleting downloads in driver
    subclass by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16423
    * [java] refactor(remote/command): Merge overload's business logic by
    @​nnnnoel in https://github.com/SeleniumHQ/selenium/pull/14469
    * [py] Fix default rpId in virtual authenticator by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16428
    * make augmentation of HasBiDi/HasDevTools lazy-loaded by @​asolntsev in
    https://github.com/SeleniumHQ/selenium/pull/16338
    * [py] Update docstrings style by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16427
    * [py] Support Python 3.14 and drop Python 3.9 by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16342
    * Removing FF guard for canListenToDownloadWillBeginEvent by @​diemol in
    https://github.com/SeleniumHQ/selenium/pull/16439
    * Adapting the browser_protocol file fetching to the file structure
    change. by @​diemol in https://github.com/SeleniumHQ/selenium/pull/16440
     ... (truncated)
    
    ## 4.36.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at trunk -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [py]: close ipv6 port in case of error by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16165
    * [docs] Update issue label in CONTRIBUTING.md by @​pallavigitwork in
    https://github.com/SeleniumHQ/selenium/pull/16169
    * [py][docs]: update dead API docs link to API reference in `index.rst`
    by @​navin772 in https://github.com/SeleniumHQ/selenium/pull/16170
    * [grid] close the HttpClient after the session is gone by @​joerg1985
    in https://github.com/SeleniumHQ/selenium/pull/16182
    * [py] Update docstring and comments in keys.py by @​Aidoni0797 in
    https://github.com/SeleniumHQ/selenium/pull/16187
    * [dotnet] [bidi] Simplify type naming of internal command parameters by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16188
    * [py] Fix formatting by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16189
    * [dotnet] [bidi] Support WebExtension module by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15850
    * [rb][BiDi] Create browser module, added user context related methods
    by @​aguspe in https://github.com/SeleniumHQ/selenium/pull/15371
    * [docs] Update bug report section in CONTRIBUTING.md by
    @​pallavigitwork in https://github.com/SeleniumHQ/selenium/pull/16191
    * [dotnet] Adding flag to enable SafariDriver logging. by @​diemol in
    https://github.com/SeleniumHQ/selenium/pull/16196
    * [java] extend the scope of the properties of the HttpCommandExecutor
    class by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16186
    * [dotnet] [bidi] Serialize base64 encoded string directly to bytes by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16203
    * [dotnet] [bidi] Make cookie expiry as TimeSpan by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16204
    * [grid] Improve readTimeout in handle session between Router and Node
    by @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/16163
    * [py] Fix type annotation error and raise clearer error message by
    @​Paresh-0007 in https://github.com/SeleniumHQ/selenium/pull/16174
    * [java] Unifying select class by @​vicky-iv in
    https://github.com/SeleniumHQ/selenium/pull/16220
    * [rust] Update dependency rules_cc to v0.2.0 by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16198
    * [js] Update testing-library monorepo by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16173
    * [js] Update dependency tmp to ^0.2.5 by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16172
    * [dotnet] Update dependency System.Text.Json to 8.0.6 by
    @​renovate[bot] in https://github.com/SeleniumHQ/selenium/pull/16171
    * [js] Update dependency react-router-dom to v6.30.1 by @​renovate[bot]
    in https://github.com/SeleniumHQ/selenium/pull/16076
    * [js] Update material-ui monorepo to v5.18.0 by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16062
    * [js] Update dependency ws to ^8.18.3 by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16009
    * [js] Update react monorepo by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/15949
    * [java] Update dependency net.bytebuddy:byte-buddy to v1.17.7 by
    @​renovate[bot] in https://github.com/SeleniumHQ/selenium/pull/16237
    * [py] Update dependency charset-normalizer to v3.4.3 by @​renovate[bot]
    in https://github.com/SeleniumHQ/selenium/pull/16239
    * [py] Update dependency cryptography to v45.0.6 by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/16240
    * Revert "[py] Update dependency charset-normalizer to v3.4.3" by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16242
    * Revert "[py] Update dependency cryptography to v45.0.6" by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/16243
    * [py] Bump dependencies for dev and fix script by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16244
    * [dotnet] Help old .net framework copy selenium manager to output by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/16228
    * [java] Add hooks around getScreenshotAs in WebDriverListener #​16232
    by @​giulong in https://github.com/SeleniumHQ/selenium/pull/16233
    * [py][bidi]: enable `history_updated` event test by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/16236
    * [py] Bump ruff version for linting/formatting by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16254
    * [py][bidi]: use bidi `navigate` command in network tests by @​navin772
    in https://github.com/SeleniumHQ/selenium/pull/16251
    * [dotnet] Fix find port for IPv4 only environments by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16216
    * [dotnet] [bidi] Adjust cookie expiry type according spec (unix
    seconds) by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16218
     ... (truncated)
    
    ## 4.35.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at 1c58e5028bc5eaa94b12b856c2d4a87efa5363f5 -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [dotnet] [bidi] Get tree command returns GetTreeResult object by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/15978
    * [dotnet] [bidi] Initialize internal modules without Lazy by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/15979
    * [py] Bump dependencies for building distribution wheel by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/15977
    * bump zip version 2.6.1 -> 4.2.0 by @​MRTamalampudi in
    https://github.com/SeleniumHQ/selenium/pull/15980
    * [py][bidi]: add note for `enable_webextensions = False` by @​navin772
    in https://github.com/SeleniumHQ/selenium/pull/15981
    * [py][bidi]: add high level API for script module - `pin`, `unpin` and
    `execute` by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15936
    * [py][java][rb][ci]: use pinned browsers in CI by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15987
    * [java] Remove deprecated AppCacheStatus enum from the HTML5 package by
    @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/15973
    * [java] Feat 14291/jspecify nullable annotation edge driver service by
    @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/15972
    * [java] Fix Unicode value for OPTION key in Keys enum by @​iampopovich
    in https://github.com/SeleniumHQ/selenium/pull/15966
    * [dotnet][java][js][py][rb][rust] Update rules_jvm_external digest to
    aca619b by @​renovate[bot] in
    https://github.com/SeleniumHQ/selenium/pull/15951
    * [java] Removing old stream collectors required by Java 8 by @​zodac in
    https://github.com/SeleniumHQ/selenium/pull/15523
    * [java] Use static Patterns for regex-matching by @​zodac in
    https://github.com/SeleniumHQ/selenium/pull/15499
    * [java] Point made as immutable by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/15511
    * [java] Feat 14291/jspecify nullable annotation chrome driver såervice
    by @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/15998
    * [py] Bump dev dependencies by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16002
    * [grid] Add "URI" to the list of sort-by choices on Overview UI by
    @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/16004
    * [java] Add @​Nullable annotations to Firefox and Gecko driver service
    by @​iampopovich in https://github.com/SeleniumHQ/selenium/pull/15999
    * [java] Add JSpecify nullable annotations to SafariDriverService
    parameters by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16000
    * [java] Add @​Nullable annotations to InternetExplorerDriverService
    parameters by @​iampopovich in
    https://github.com/SeleniumHQ/selenium/pull/16001
    * use generics for AbstractFindByBuilder to avoid excessive casting by
    @​asolntsev in https://github.com/SeleniumHQ/selenium/pull/15526
    * [js] Update dependency @​emotion/styled to v11.14.1 by @​renovate[bot]
    in https://github.com/SeleniumHQ/selenium/pull/15997
    * [rust] Update which from 7.0.3 to 8.0.0 by @​musicinmybrain in
    https://github.com/SeleniumHQ/selenium/pull/15965
    * Fix various typos by @​noritaka1166 in
    https://github.com/SeleniumHQ/selenium/pull/16012
    * [java] JSpecify annotations for By locators by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/14372
    * Fix email address in .mailmap by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/16017
    * Fix typos in javascript & rb by @​noritaka1166 in
    https://github.com/SeleniumHQ/selenium/pull/16019
    * [java] JSpecify annotations for capabilities by @​mk868 in
    https://github.com/SeleniumHQ/selenium/pull/14397
    * Fix various typos in comments by @​noritaka1166 in
    https://github.com/SeleniumHQ/selenium/pull/16022
    * [dotnet] Fix typos by @​noritaka1166 in
    https://github.com/SeleniumHQ/selenium/pull/16032
    * [dotnet] [bidi] Add UnhandledPromptBehavior option to create User
    Context by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16034
    * [py] Fix path in unit test so it works cross-platform by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/16033
    * [py][bidi]: implement bidi module - emulation by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15819
    * [py] Fix API doc generation script and include BiDi Emulation docs by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16037
    * [py] Allow free_port() to bind to IPv6 if IPv4 is unavailable by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/16003
    * [build] Update base URL for Edge web driver by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16057
    * [rust] Update base URL for Edge web driver by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/16056
     ... (truncated)
    
    ## 4.34.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at 2a4c61c498207b17cdb2f5f987c7c71dca146c2d -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [ci] Clear warning from Grid UI component tests by @​VietND96 in
    https://github.com/SeleniumHQ/selenium/pull/15783
    * [py] Fix pytest_ignore_collect hook to respect --ignore by @​mgorny in
    https://github.com/SeleniumHQ/selenium/pull/15787
    * [py] Increase timeout in devtools test by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15793
    * [py] Upgrade type hints by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15784
    * [dotnet] [bidi] Add AcceptInsecureCerts and Proxy options when create
    new user context by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15795
    * [grid] Silent fail on invalid log level by @​Oxilod in
    https://github.com/SeleniumHQ/selenium/pull/15796
    * Bump setup-bazel action by @​p0deje in
    https://github.com/SeleniumHQ/selenium/pull/15802
    * Don't silence stderr in format.sh by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15804
    * [dotnet] [bidi] Declare allowed nullable objects in constructors type
    by @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/15809
    * Fix type error for attribute in remote_connection.py by @​Bradltr95 in
    https://github.com/SeleniumHQ/selenium/pull/15810
    * [py] Lint Python with ruff by @​p0deje in
    https://github.com/SeleniumHQ/selenium/pull/15811
    * fixed error in selenium/webdriver/common/bidi/common.py:19 by
    @​pallavigitwork in https://github.com/SeleniumHQ/selenium/pull/15814
    * [py] Fix import for type hint by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15817
    * [py] Bump ruff version by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15818
    * [dotnet] [bidi] Simplify modules namespace for end users (breaking
    change) by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15820
    * [dotnet] Remove unnecessary stylecop files by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15824
    * [py] Lint and format all python files by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15828
    * [py][bidi]: add `enable_webextensions` option for chromium-based
    browsers by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15794
    * [py] Auto-generate Python API docs from code by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15822
    * [py] Fix python API docs publishing at readthedocs by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15832
    * Change flag for Chrome/Edge headless mode in tests by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15831
    * [py] Cleanup tox config by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15833
    * [rb] Add support for beta chrome by @​aguspe in
    https://github.com/SeleniumHQ/selenium/pull/15417
    * Revert "[rb] Add support for beta chrome" by @​aguspe in
    https://github.com/SeleniumHQ/selenium/pull/15837
    * [py] Fix: Mypy type annotation errors by @​ShauryaDusht in
    https://github.com/SeleniumHQ/selenium/pull/15841
    * [py] New script to update Python dependencies by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15845
    * fixed errors in browser.py for 15697 by @​pallavigitwork in
    https://github.com/SeleniumHQ/selenium/pull/15847
    * [py][bidi]: implement bidi permissions module by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15830
    * [py] Regeneratee py/docs/source/api.rst by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15856
    * [dotnet] Align CS projects name to understand the editing context by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/15843
    * [py][bidi]: enable edge bidi storage test - `test_get_all_cookies` by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/15859
    * Caching the size/length in loops to slightly improve performance by
    @​LuisOsv in https://github.com/SeleniumHQ/selenium/pull/15852
    * Update exceptions.py by @​adolfoarmas in
    https://github.com/SeleniumHQ/selenium/pull/15862
    * Revert "Update exceptions.py" by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15864
    * [py] Re-apply #​15862 by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15865
    * [py] fix driver_element_finding_tests.py by @​Delta456 in
    https://github.com/SeleniumHQ/selenium/pull/15863
    * [py] Fix another broken test by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15866
     ... (truncated)
    
    ## 4.33.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at 2c6aaad03a575cd93e4f063f91404e3ae66a7470 -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [py] Exclude devtools directory from type checking by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15695
    * [py] Add clean_options fixture and remove all Python tests from
    .skipped-tests by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15696
    * [java][bidi]: enable tests for storage module for edge by @​navin772
    in https://github.com/SeleniumHQ/selenium/pull/15667
    * [py][bidi]: add bidi storage module by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15669
    * [build] allow GitHub Actions runner to use 4GB for JVM Heap by
    @​titusfortner in https://github.com/SeleniumHQ/selenium/pull/15692
    * update old freenode channel link to libera by @​t7ru in
    https://github.com/SeleniumHQ/selenium/pull/15698
    * fixing mypy error from #​15693 by @​bandophahita in
    https://github.com/SeleniumHQ/selenium/pull/15705
    * [java] Removing deprecated items in Require.java by @​diemol in
    https://github.com/SeleniumHQ/selenium/pull/15711
    * [java] Removing RemoteStatus as it was deprecated. by @​diemol in
    https://github.com/SeleniumHQ/selenium/pull/15712
    * [rb] move all guard and zipper tests to unit tests by @​titusfortner
    in https://github.com/SeleniumHQ/selenium/pull/15717
    * [rust] Replace WMIC commands (deprecated) by WinAPI in Windows by
    @​bonigarcia in https://github.com/SeleniumHQ/selenium/pull/15363
    * [py][BiDi] use constant for LogLevel by @​Delta456 in
    https://github.com/SeleniumHQ/selenium/pull/15677
    * Let firefox choose the bidi port by default by @​tomhughes in
    https://github.com/SeleniumHQ/selenium/pull/15727
    * [rb] Upgrade to Ruby 3.2 by @​p0deje in
    https://github.com/SeleniumHQ/selenium/pull/15714
    * [py] Missing Headers Assignment in Network Class’s _on_request() by
    @​shbenzer in https://github.com/SeleniumHQ/selenium/pull/15736
    * [py] correct type annotations of default-None params by
    @​DeflateAwning in https://github.com/SeleniumHQ/selenium/pull/15341
    * [py] Add missing 'id' property to ShadowRoot class by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15739
    * [py] Bump Python package requirements to latest versions by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/15731
    * [py] Use ruff for linting and code formatting by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15746
    * [py]: return `message` as part of exception in `execute` method by
    @​navin772 in https://github.com/SeleniumHQ/selenium/pull/15751
    * [py][tests]: check for .txt file in remote download test by @​navin772
    in https://github.com/SeleniumHQ/selenium/pull/15758
    * [java] Removing deprecated `setScriptTimeout` and `pageLoadTimeout`.
    by @​diemol in https://github.com/SeleniumHQ/selenium/pull/15764
    * [py][bidi]: add bidi webExtension module by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15749
    * [py] Better error for downloads on local webdrivers by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15756
    * [py] Add missing modules to python API docs by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15779
    * [ci] Workflow for Grid UI component tests by @​VietND96 in
    https://github.com/SeleniumHQ/selenium/pull/15778
    * [grid] UI Sessions capability fields to display as additional columns
    by @​VietND96 in https://github.com/SeleniumHQ/selenium/pull/15759
    * [grid] UI Overview is able to see live preview per Node by @​VietND96
    in https://github.com/SeleniumHQ/selenium/pull/15777
    
    ## New Contributors
    * @​t7ru made their first contribution in
    https://github.com/SeleniumHQ/selenium/pull/15698
    * @​tomhughes made their first contribution in
    https://github.com/SeleniumHQ/selenium/pull/15727
    * @​DeflateAwning made their first contribution in
    https://github.com/SeleniumHQ/selenium/pull/15341
    
    </details>
    
    **Full Changelog**:
    https://github.com/SeleniumHQ/selenium/compare/selenium-4.32.0...selenium-4.33.0
    
    ## 4.32.0
    
    ## Detailed Changelogs by Component
    
    <img src="https://www.selenium.dev/images/programming/java.svg"
    width="20" height="20">
    **[Java](https://github.com/SeleniumHQ/selenium/blob/trunk/java/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/python.svg" width="20"
    height="20">
    **[Python](https://github.com/SeleniumHQ/selenium/blob/trunk/py/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/dotnet.svg" width="20"
    height="20">
    **[DotNet](https://github.com/SeleniumHQ/selenium/blob/trunk/dotnet/CHANGELOG)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/ruby.svg" width="20"
    height="20">
    **[Ruby](https://github.com/SeleniumHQ/selenium/blob/trunk/rb/CHANGES)**
    &nbsp;&nbsp;&nbsp; | &nbsp;&nbsp;&nbsp;<img
    src="https://www.selenium.dev/images/programming/javascript.svg"
    width="20" height="20">
    **[JavaScript](https://github.com/SeleniumHQ/selenium/blob/trunk/javascript/selenium-webdriver/CHANGES.md)**
    <br>
    
    
    
    <!-- Release notes generated using configuration in .github/release.yml
    at d17c8aa95092dc25ae64f12e7abdc844cf3503f0 -->
    
    ## What's Changed
    <details>
    <summary>Click to see all the changes included in this release</summary>
    
    * [py] Fix test args for --headless and --bidi by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15567
    * [py] Only skip WebKit tests on Windows by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15470
    * [dotnet] [bidi] Revisit some core functionality to deserialize without
    intermediate `JsonElement` allocation by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15575
    * [py] Fix broken test for chromedriver logging by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15579
    * [py] Fix test for w3c touch pointer properties by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15580
    * [py] Fix FedCM tests leaking state by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15583
    * [dotnet] [bidi] Address BiDi's JSON converter AOT warnings by
    @​RenderMichael in https://github.com/SeleniumHQ/selenium/pull/15390
    * [dotnet] [bidi] Added missing GenericLogEntry log entry type in Script
    module by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15591
    * [grid] Ignored options when they are prefixed, safari specif as well
    by @​diemol in https://github.com/SeleniumHQ/selenium/pull/15574
    * [py] Remove broken logo from Sphinx generated API docs by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/15597
    * [py] Fix PyTest configuration for WPEWebKit by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15602
    * [py] Fix failing test for Edge logging by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15605
    * [rb] Add PrintOptions Implementation for Ruby WebDriver by @​yvsvarma
    in https://github.com/SeleniumHQ/selenium/pull/15158
    * [py] BiDi Network implementation of Intercepts and Auth in Python by
    @​shbenzer in https://github.com/SeleniumHQ/selenium/pull/14592
    * [py] Use XWayland for internal Python Firefox tests by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15601
    * [py] Use mock.patch for environment variables in tests by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/15607
    * [ruby] fix lint for print_options.rb by @​Delta456 in
    https://github.com/SeleniumHQ/selenium/pull/15608
    * [py] Configure readthedocs publishing for Python API docs by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/15614
    * [py] Fix select being able to select options hidden by css rules by
    @​FFederi in https://github.com/SeleniumHQ/selenium/pull/15135
    * [py][bidi]: Implement BiDi browser module by @​navin772 in
    https://github.com/SeleniumHQ/selenium/pull/15616
    * [dotnet] [bidi] Combine network interception to apply rules (breaking
    change) by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15603
    * [dotnet] [bidi] Add strongly-typed `LocalValue.ConvertFrom` overloads
    by @​RenderMichael in https://github.com/SeleniumHQ/selenium/pull/15532
    * [py] Add missing modules to Python API docs by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15624
    * [dotnet] [bidi] Do not throw when CallFunction or Evaluate return
    exceptional result (breaking change) by @​RenderMichael in
    https://github.com/SeleniumHQ/selenium/pull/15521
    * [py] Skip bidi tests on browsers that don't support bidi by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/15625
    * [py] complete
    `test_should_throw_an_exception_if_an_alert_has_not_been_dealt_with_and_dismiss_the_alert`
    by @​Delta456 in https://github.com/SeleniumHQ/selenium/pull/15559
    * [py] Remove unused xfail on chrome/edge service tests by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/15637
    * [py] Adjust xfail markers for window size/position tests by
    @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/15638
    * [py] Call service.stop() when session can't be started by @​cgoldberg
    in https://github.com/SeleniumHQ/selenium/pull/15636
    * [dotnet] [bidi] Reuse memory when receiving websocket messages by
    @​nvborisenko in https://github.com/SeleniumHQ/selenium/pull/15640
    * [py] Remove logging API for non-Chromium browsers by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15641
    * [py] Raise TypeError when creating webdriver.Remote() without options
    by @​cgoldberg in https://github.com/SeleniumHQ/selenium/pull/15619
    * [py] Upgrade dependencies for mypy tox environment by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15642
    * [py] Fix Remote Firefox tests on Linux/Wayland by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15648
    * [dotnet] Enhance Selenium Manager platform detection by @​nvborisenko
    in https://github.com/SeleniumHQ/selenium/pull/15649
    * [dotnet] Use namespace file scoped by @​nvborisenko in
    https://github.com/SeleniumHQ/selenium/pull/15651
    * [py] Fix flaky WebDriverWait tests by @​cgoldberg in
    https://github.com/SeleniumHQ/selenium/pull/15650
     ... (truncated)
    
    Commits viewable in [compare
    view](https://github.com/SeleniumHQ/selenium/compare/selenium-4.31.0...selenium-4.41.0).
    </details>
    
    [![Dependabot compatibility
    score](https://dependabot-badges.githubapp.com/badges/compatibility_score?dependency-name=Selenium.WebDriver&package-manager=nuget&previous-version=4.31.0&new-version=4.41.0)](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores)
    
    Dependabot will resolve any conflicts with this PR as long as you don't
    alter it yourself. You can also trigger a rebase manually by commenting
    `@dependabot rebase`.
    
    [//]: # (dependabot-automerge-start)
    [//]: # (dependabot-automerge-end)
    
    ---
    
    <details>
    <summary>Dependabot commands and options</summary>
    <br />
    
    You can trigger Dependabot actions by commenting on this PR:
    - `@dependabot rebase` will rebase this PR
    - `@dependabot recreate` will recreate this PR, overwriting any edits
    that have been made to it
    - `@dependabot show <dependency name> ignore conditions` will show all
    of the ignore conditions of the specified dependency
    - `@dependabot ignore this major version` will close this PR and stop
    Dependabot creating any more for this major version (unless you reopen
    the PR or upgrade to it yourself)
    - `@dependabot ignore this minor version` will close this PR and stop
    Dependabot creating any more for this minor version (unless you reopen
    the PR or upgrade to it yourself)
    - `@dependabot ignore this dependency` will close this PR and stop
    Dependabot creating any more for this dependency (unless you reopen the
    PR or upgrade to it yourself)
    
    
    </details>
    
    Signed-off-by: dependabot[bot] <support@github.com>
    Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
    Co-authored-by: PhilipWoulfe <philip.woulfe@gmail.com>
    Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

    Labels

    B-support Issue or PR related to support classes C-dotnet .NET Bindings Review effort 2/5

    Projects

    None yet

    Development

    Successfully merging this pull request may close these issues.

    2 participants