Skip to content

Commit

Permalink
[dotnet] Safari driver supports /status endpoint (SeleniumHQ#15066)
Browse files Browse the repository at this point in the history
  • Loading branch information
nvborisenko authored Jan 12, 2025
1 parent 6da3095 commit 61dc85b
Showing 1 changed file with 0 additions and 50 deletions.
50 changes: 0 additions & 50 deletions dotnet/src/webdriver/Safari/SafariDriverService.cs
Original file line number Diff line number Diff line change
Expand Up @@ -87,56 +87,6 @@ protected override bool HasShutdown
get { return false; }
}

/// <summary>
/// Gets a value indicating whether the service is responding to HTTP requests.
/// </summary>
protected override bool IsInitialized
{
get
{
bool isInitialized = false;

Uri serviceHealthUri = new Uri(this.ServiceUrl, new Uri("/session/FakeSessionIdForPollingPurposes", UriKind.Relative));

// Since Firefox driver won't implement the /session end point (because
// the W3C spec working group stupidly decided that it isn't necessary),
// we'll attempt to poll for a different URL which has no side effects.
// We've chosen to poll on the "quit" URL, passing in a nonexistent
// session id.
using (var httpClient = new HttpClient())
{
httpClient.DefaultRequestHeaders.ConnectionClose = true;
httpClient.Timeout = TimeSpan.FromSeconds(5);

using (var httpRequest = new HttpRequestMessage(HttpMethod.Delete, serviceHealthUri))
{
try
{
using (var httpResponse = Task.Run(async () => await httpClient.SendAsync(httpRequest)).GetAwaiter().GetResult())
{
isInitialized = (httpResponse.StatusCode == HttpStatusCode.OK
|| httpResponse.StatusCode == HttpStatusCode.InternalServerError
|| httpResponse.StatusCode == HttpStatusCode.NotFound)
&& httpResponse.Content.Headers.ContentType.MediaType.StartsWith("application/json", StringComparison.OrdinalIgnoreCase);
}
}

// Checking the response from deleting a nonexistent session. Note that we are simply
// checking that the HTTP status returned is a 200 status, and that the resposne has
// the correct Content-Type header. A more sophisticated check would parse the JSON
// response and validate its values. At the moment we do not do this more sophisticated
// check.
catch (Exception ex) when (ex is HttpRequestException || ex is TaskCanceledException)
{
// Do nothing. The exception is expected, meaning driver service is not initialized.
}
}
}

return isInitialized;
}
}

/// <summary>
/// Creates a default instance of the SafariDriverService.
/// </summary>
Expand Down

0 comments on commit 61dc85b

Please sign in to comment.