G4.Abstraction.WebDriver
2024.12.23.5
dotnet add package G4.Abstraction.WebDriver --version 2024.12.23.5
NuGet\Install-Package G4.Abstraction.WebDriver -Version 2024.12.23.5
<PackageReference Include="G4.Abstraction.WebDriver" Version="2024.12.23.5" />
paket add G4.Abstraction.WebDriver --version 2024.12.23.5
#r "nuget: G4.Abstraction.WebDriver, 2024.12.23.5"
// Install G4.Abstraction.WebDriver as a Cake Addin #addin nuget:?package=G4.Abstraction.WebDriver&version=2024.12.23.5 // Install G4.Abstraction.WebDriver as a Cake Tool #tool nuget:?package=G4.Abstraction.WebDriver&version=2024.12.23.5
G4.Abstraction.WebDriver
G4.Abstraction.WebDriver provides an abstraction layer for creating WebDriver instances with configurable parameters. This library allows developers to initialize WebDriver instances with options for command timeouts, driver types, binary paths (local file path or grid endpoint), service configurations, and driver capabilities. It simplifies the setup process for automated browser interactions in remote or local environments.
Installation
To install G4.Abstraction, add the NuGet package:
dotnet add package G4.Abstraction.WebDriver
Features
- Driver Creation Abstraction: Simplifies the process of creating WebDriver instances with custom configuration.
- Plugin-Based Driver Management: Supports adding custom driver plugins to extend functionality.
- Service Configuration: Supports service parameters for additional customization.
- Serialization Options: Uses camel-case naming for JSON serialization and deserialization.
- Remote and Local Driver Support: Detects if drivers are local (using a file path) or remote (using a grid endpoint URL).
Usage
1. Local Driver Example
In this example, the driverBinaries
path points to a local file path where the driver binary (e.g., MicrosoftEdgeDriver.exe
) is located. This configuration is suitable for running WebDriver instances on the local machine.
using G4.Abstraction;
var driverParams = new Dictionary<string, object>
{
{ "driver", "MicrosoftEdgeDriver" },
{ "commandTimeout", 60000 },
{ "driverBinaries", @"C:\path\to\MicrosoftEdgeDriver.exe" }, // Local file path
{ "capabilities", new CapabilitiesModel
{
AlwaysMatch = new Dictionary<string, object>
{
{ "browserName", "MicrosoftEdge" },
{ "platformName", "Windows 10" }
},
FirstMatch = new List<Dictionary<string, object>>
{
new Dictionary<string, object> { { "browserVersion", "latest" } }
}
}
}
};
var driverFactory = new DriverFactory(driverParams);
var webDriver = driverFactory.NewDriver();
2. Remote Driver Example
For remote setups, the driverBinaries
parameter points to a grid endpoint URL (e.g., Selenium Grid or BrowserStack), which allows running tests on remote browsers. This configuration is useful for distributed testing across different platforms.
using G4.Abstraction;
var driverParams = new Dictionary<string, object>
{
{ "driver", "MicrosoftEdgeDriver" },
{ "commandTimeout", 60000 },
{ "driverBinaries", "http://localhost:4444/wd/hub" }, // Grid endpoint URL
{ "capabilities", new CapabilitiesModel
{
AlwaysMatch = new Dictionary<string, object>
{
{ "browserName", "MicrosoftEdge" },
{ "platformName", "Windows 10" }
},
FirstMatch = new List<Dictionary<string, object>>
{
new Dictionary<string, object> { { "browserVersion", "latest" } },
new Dictionary<string, object> { { "headless", true } }
}
}
}
};
var driverFactory = new DriverFactory(driverParams);
var webDriver = driverFactory.NewDriver();
Work in Progress
- Service Parameter Integration: Future versions will include support for service parameters during the initialization of new driver instances.
Error Handling
The DriverFactory
includes detailed error handling. If the specified driver or initialization method is not found, a NotImplementedException
or MissingMethodException
is thrown with a detailed error message.
License
This library is released under the Apache License 2.0.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net8.0
- G4.Cache (>= 2024.11.22.8)
- G4.WebDriver (>= 2024.11.14.75)
- G4.WebDriver.Remote.Android (>= 2024.11.14.75)
- G4.WebDriver.Remote.Appium (>= 2024.11.14.75)
- G4.WebDriver.Remote.Chrome (>= 2024.11.14.75)
- G4.WebDriver.Remote.Chromium (>= 2024.11.14.75)
- G4.WebDriver.Remote.Edge (>= 2024.11.14.75)
- G4.WebDriver.Remote.Firefox (>= 2024.11.14.75)
- G4.WebDriver.Remote.Opera (>= 2024.11.14.75)
- G4.WebDriver.Remote.Simulator (>= 2024.11.14.75)
- G4.WebDriver.Remote.Uia (>= 2024.11.14.75)
- Newtonsoft.Json (>= 13.0.3)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
2024.12.23.5 | 68 | 12/23/2024 |