Skip to content

Conversation

@nvborisenko
Copy link
Member

@nvborisenko nvborisenko commented Sep 24, 2025

User description

https://w3c.github.io/webdriver-bidi/#cddl-type-browsingcontextbasenavigationinfo

Be more closer to the spec. Actually this type is interface. I am reading the spec (example https://w3c.github.io/webdriver-bidi/#event-browsingContext-downloadEnd) as many types might include some another. In .NET it is impossible to inherit from multiple types, but we can from interfaces.

🔗 Related Issues

💥 What does this PR do?

Try to interpretate the spec as is. If new property will be added in BaseNavigationInfo type, we can add it easy, and into all other dependent types.


PR Type

Enhancement


Description

  • Introduce IBaseNavigationInfo interface for BiDi navigation types

  • Implement interface in existing NavigationInfo record

  • Align .NET implementation with WebDriver BiDi specification

  • Enable multiple inheritance pattern for navigation info types


Diagram Walkthrough

flowchart LR
  A["IBaseNavigationInfo Interface"] --> B["NavigationInfo Record"]
  A --> C["Future Navigation Types"]
  B --> D["BiDi Spec Compliance"]
Loading

File Walkthrough

Relevant files
Enhancement
IBaseNavigationInfo.cs
Add IBaseNavigationInfo interface definition                         

dotnet/src/webdriver/BiDi/BrowsingContext/IBaseNavigationInfo.cs

  • Create new interface with navigation properties
  • Define Context, Navigation, Timestamp, and Url properties
  • Add standard Apache license header
+33/-0   
NavigationInfo.cs
Implement interface in NavigationInfo record                         

dotnet/src/webdriver/BiDi/BrowsingContext/NavigationInfo.cs

  • Implement IBaseNavigationInfo interface in NavigationInfo record
  • Maintain existing inheritance from BrowsingContextEventArgs
+1/-1     

@selenium-ci selenium-ci added the C-dotnet .NET Bindings label Sep 24, 2025
@qodo-merge-pro
Copy link
Contributor

PR Reviewer Guide 🔍

Here are some key observations to aid the review process:

🎫 Ticket compliance analysis 🔶

5678 - Partially compliant

Compliant requirements:

Non-compliant requirements:

  • Investigate and resolve ConnectFailure on ChromeDriver instantiation.
  • Ensure subsequent ChromeDriver instances do not fail.
  • Provide preventative steps/code changes for connection refusals.
  • Validate on specified environment/versions.

Requires further human verification:

  • Reproduce and validate behavior on Ubuntu 16.04.4 with Chrome 65/Chromedriver 2.35 and Selenium 3.9.0.

1234 - Partially compliant

Compliant requirements:

Non-compliant requirements:

  • Ensure click() triggers JavaScript in link href for Firefox 42 with Selenium 2.48.x.
  • Provide fix/tests for Firefox driver behavior.

Requires further human verification:

  • Manual verification in Firefox 42 with legacy Selenium versions (historical).
⏱️ Estimated effort to review: 1 🔵⚪⚪⚪⚪
🧪 No relevant tests
🔒 No security concerns identified
⚡ Recommended focus areas for review

API Surface

Introducing a public interface is a breaking API change if consumers relied on concrete record members only. Confirm intended public exposure and versioning implications.

public interface IBaseNavigationInfo
{
    BrowsingContext Context { get; }

    Navigation? Navigation { get; }

    DateTimeOffset Timestamp { get; }

    string Url { get; }
}
Contract Consistency

Ensure all interface properties are correctly exposed by the record (nullability, naming, types) and align with BiDi spec; verify Url non-null and Navigation optional semantics.

public sealed record NavigationInfo(BiDi BiDi, BrowsingContext Context, Navigation? Navigation, DateTimeOffset Timestamp, string Url)
    : BrowsingContextEventArgs(BiDi, Context), IBaseNavigationInfo;

@qodo-merge-pro
Copy link
Contributor

PR Code Suggestions ✨

Explore these optional code suggestions:

CategorySuggestion                                                                                                                                    Impact
General
Make URL property nullable for safety

In the IBaseNavigationInfo interface, change the Url property from string to
nullable string? to improve API safety and more accurately represent cases where
a URL may not be available.

dotnet/src/webdriver/BiDi/BrowsingContext/IBaseNavigationInfo.cs [32]

-string Url { get; }
+string? Url { get; }
  • Apply / Chat
Suggestion importance[1-10]: 6

__

Why: This is a good API design suggestion that uses C#'s nullable reference types to make the interface contract more robust and explicit, forcing consumers to handle cases where a URL might not be present.

Low
  • More

@nvborisenko nvborisenko merged commit b3b66a0 into SeleniumHQ:trunk Sep 30, 2025
13 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants