Skip to content

Commit

Permalink
Fix unhandled alerts not being properly ignored (elixir-wallaby#779)
Browse files Browse the repository at this point in the history
This is an improvement over elixir-wallaby#778. By falling back to the full message value from Chromedriver, we can correctly get the `:unexpected_alert` condition to match on the bizarre, not-quite-JSON message from Chromedriver like:

```
    "message" => "unexpected alert open: {Alert text : Error loading data, please refresh and try again}\n  (Session info: chrome-headless-shell=125.0.6422.142)\n  (Driver info: chromedriver=125.0.6422.78 (14db42ec38aded3304a3e624a0a038e02956b87e-refs/branch-heads/6422@{#1088}),platform=Mac OS X 14.5.0 x86_64)"
```

Applying this patch to my local copy, my default-configured Chromedriver correctly ignores the alert and my tests that passed on v0.36.6 again pass.
  • Loading branch information
s3cur3 authored and alinmarsh committed Oct 8, 2024
1 parent 3378be3 commit 00015a9
Showing 1 changed file with 8 additions and 13 deletions.
21 changes: 8 additions & 13 deletions lib/wallaby/httpclient.ex
Original file line number Diff line number Diff line change
Expand Up @@ -165,19 +165,14 @@ defmodule Wallaby.HTTPClient do

defp coerce_json_message(%{"value" => %{"message" => message} = value} = response) do
value =
case Regex.named_captures(~r/(?<type>.*): (?<payload>{.*})\n.*/, message) do
%{"payload" => payload, "type" => type} ->
message =
case Jason.decode(payload) do
{:ok, message} -> message
_ -> payload
end

%{
"message" => message,
"type" => type
}

with %{"payload" => payload, "type" => type} <-
Regex.named_captures(~r/(?<type>.*): (?<payload>{.*})\n.*/, message),
{:ok, message} <- Jason.decode(payload) do
%{
"message" => message,
"type" => type
}
else
_ ->
value
end
Expand Down

0 comments on commit 00015a9

Please sign in to comment.