You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The cast to IWebDriverObjectReference could throw InvalidCastException if element is not of the expected type. Add a type check and handle the case when the cast fails.
-return ((IWebDriverObjectReference)this.element).ObjectReferenceId;+if (this.element is IWebDriverObjectReference reference)+ return reference.ObjectReferenceId;+throw new InvalidOperationException("Element does not implement IWebDriverObjectReference");
Apply this suggestion
Suggestion importance[1-10]: 9
Why: The suggestion addresses a critical runtime safety issue by properly handling potential InvalidCastException, which could crash the application. The improved code provides better error handling and clearer error messages.
9
Validate constructor parameter for null
The constructor should validate that parentDriver is not null to prevent NullReferenceException in subsequent operations.
public WebElement(WebDriver parentDriver, string id)
{
- this.driver = parentDriver;+ this.driver = parentDriver ?? throw new ArgumentNullException(nameof(parentDriver));
this.elementId = id ?? throw new ArgumentNullException(nameof(id));
}
Apply this suggestion
Suggestion importance[1-10]: 8
Why: The suggestion prevents potential NullReferenceException by validating a critical constructor parameter. This is an important defensive programming practice that improves code reliability.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
User description
Thanks for contributing to Selenium!
A PR well described will help maintainers to quickly review and merge it
Before submitting your PR, please check our contributing guidelines.
Avoid large PRs, help reviewers by making them as simple and short as possible.
Description
Annotates nullability on interactions. The last type not annotated is the big
Actionsone.Motivation and Context
Contributes to #14640
Types of changes
Checklist
PR Type
Enhancement
Description
Annotated nullability across multiple files in the
dotnetproject.Improved code safety with
ArgumentNullExceptionchecks.Refactored properties to use expression-bodied members.
Marked private fields as
readonlywhere applicable.Changes walkthrough 📝
ElementCoordinates.cs
Annotate nullability and refactor `ElementCoordinates`.dotnet/src/webdriver/ElementCoordinates.cs
ArgumentNullExceptionfor constructor parameter.elementfield asreadonly.ActionSequence.cs
Annotate nullability and refactor `ActionSequence`.dotnet/src/webdriver/Interactions/ActionSequence.cs
ArgumentNullExceptionfor constructor parameter.interactionsfield asreadonly.IAction.cs
Enable nullable reference types in `IAction`.dotnet/src/webdriver/Interactions/IAction.cs
ICoordinates.cs
Enable nullable reference types in `ICoordinates`.dotnet/src/webdriver/Interactions/ICoordinates.cs
InputDeviceKind.cs
Enable nullable reference types in `InputDeviceKind`.dotnet/src/webdriver/Interactions/InputDeviceKind.cs
Interaction.cs
Annotate nullability and refactor `Interaction`.dotnet/src/webdriver/Interactions/Interaction.cs
ArgumentNullExceptionfor constructor parameter.sourceDevice.PauseInteraction.cs
Annotate nullability and refactor `PauseInteraction`.dotnet/src/webdriver/Interactions/PauseInteraction.cs
durationfield asreadonly.WebElement.cs
Annotate nullability and improve safety in `WebElement`.dotnet/src/webdriver/WebElement.cs
ArgumentNullExceptionfor constructor parameter.