-
-
Notifications
You must be signed in to change notification settings - Fork 8.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Refactoring usage of command executors in .NET.
We now use the same algorithm for creating and using a "command executor" for all current driver implementations. This removes some of the differences between Firefox and other implementations. It also prepares the way for unifying the construction of drivers using a common base Options class.
- Loading branch information
Showing
13 changed files
with
330 additions
and
283 deletions.
There are no files selected for viewing
This file contains 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
This file contains 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
79 changes: 79 additions & 0 deletions
79
dotnet/src/webdriver/Firefox/FirefoxDriverCommandExecutor.cs
This file contains 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,79 @@ | ||
// <copyright file="FirefoxDriverCommandExecutor.cs" company="WebDriver Committers"> | ||
// Copyright 2014 Software Freedom Conservancy | ||
// | ||
// Licensed under the Apache License, Version 2.0 (the "License"); | ||
// you may not use this file except in compliance with the License. | ||
// You may obtain a copy of the License at | ||
// | ||
// http://www.apache.org/licenses/LICENSE-2.0 | ||
// | ||
// Unless required by applicable law or agreed to in writing, software | ||
// distributed under the License is distributed on an "AS IS" BASIS, | ||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
// See the License for the specific language governing permissions and | ||
// limitations under the License. | ||
// </copyright> | ||
|
||
using System; | ||
using System.Collections.Generic; | ||
using System.Linq; | ||
using System.Text; | ||
using OpenQA.Selenium.Remote; | ||
using OpenQA.Selenium.Firefox.Internal; | ||
|
||
namespace OpenQA.Selenium.Firefox | ||
{ | ||
/// <summary> | ||
/// Provides a way of executing Commands using the FirefoxDriver. | ||
/// </summary> | ||
public class FirefoxDriverCommandExecutor : ICommandExecutor | ||
{ | ||
private FirefoxDriverServer server; | ||
private HttpCommandExecutor internalExecutor; | ||
private TimeSpan commandTimeout; | ||
|
||
/// <summary> | ||
/// Initializes a new instance of the <see cref="FirefoxDriverCommandExecutor"/> class. | ||
/// </summary> | ||
/// <param name="binary">The <see cref="FirefoxBinary"/> on which to make the connection.</param> | ||
/// <param name="profile">The <see cref="FirefoxProfile"/> creating the connection.</param> | ||
/// <param name="host">The name of the host on which to connect to the Firefox extension (usually "localhost").</param> | ||
/// <param name="commandTimeout">The maximum amount of time to wait for each command.</param> | ||
public FirefoxDriverCommandExecutor(FirefoxBinary binary, FirefoxProfile profile, string host, TimeSpan commandTimeout) | ||
{ | ||
this.server = new FirefoxDriverServer(binary, profile, host); | ||
this.commandTimeout = commandTimeout; | ||
} | ||
|
||
/// <summary> | ||
/// Executes a command | ||
/// </summary> | ||
/// <param name="commandToExecute">The command you wish to execute</param> | ||
/// <returns>A response from the browser</returns> | ||
public Response Execute(Command commandToExecute) | ||
{ | ||
Response toReturn = null; | ||
if (commandToExecute.Name == DriverCommand.NewSession) | ||
{ | ||
this.server.Start(); | ||
this.internalExecutor = new HttpCommandExecutor(this.server.ExtensionUri, this.commandTimeout); | ||
} | ||
|
||
// Use a try-catch block to catch exceptions for the Quit | ||
// command, so that we can get the finally block. | ||
try | ||
{ | ||
toReturn = this.internalExecutor.Execute(commandToExecute); | ||
} | ||
finally | ||
{ | ||
if (commandToExecute.Name == DriverCommand.Quit) | ||
{ | ||
this.server.Dispose(); | ||
} | ||
} | ||
|
||
return toReturn; | ||
} | ||
} | ||
} |
This file contains 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
This file contains 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
Oops, something went wrong.