Commit 5a790452 authored by Paul Noffke's avatar Paul Noffke Committed by Commit Bot

Fix chromedriver crash caused my multiple Target.attachedToTarget events.

R=johnchen@chromium.org

Change-Id: I8f21d99596c78ff7890432a790242c3876d4ba23
Reviewed-on: https://chromium-review.googlesource.com/c/1352772Reviewed-by: default avatarJohn Chen <johnchen@chromium.org>
Commit-Queue: John Chen <johnchen@chromium.org>
Cr-Commit-Position: refs/heads/master@{#613004}
parent 828f7063
......@@ -1030,3 +1030,4 @@ Venture 3 Systems LLC <*@venture3systems.com>
Vewd Software AS <*@vewd.com>
Vivaldi Technologies AS <*@vivaldi.com>
Yandex LLC <*@yandex-team.ru>
Make Positive Provar Limited <*@provartesting.com>
......@@ -156,6 +156,17 @@ Status FrameTracker::OnEvent(DevToolsClient* client,
if (!params.GetString("sessionId", &session_id))
return Status(kUnknownError,
"missing session ID in Target.attachedToTarget event");
if (frame_to_target_map_.count(target_id) > 0) {
// Since chrome 70 we are seeing multiple Target.attachedToTarget events
// for the same target_id. This is causing crashes because:
// - replacing the value in frame_to_target_map_ is causing the
// pre-existing one to be disposed
// - if there are in-flight requests for the disposed DevToolsClient
// then chromedriver is crashing in the ProcessNextMessage processing
// - the in-flight messages observed were DOM.getDocument requests from
// DomTracker.
// The fix is to not replace an pre-existing frame_to_target_map_ entry.
} else {
std::unique_ptr<WebViewImpl> child(
static_cast<WebViewImpl*>(web_view_)->CreateChild(session_id,
target_id));
......@@ -163,6 +174,7 @@ Status FrameTracker::OnEvent(DevToolsClient* client,
frame_to_target_map_[target_id] = std::move(child);
frame_to_target_map_[target_id]->ConnectIfNecessary();
}
}
} else if (method == "Target.detachedFromTarget") {
std::string target_id;
if (!params.GetString("targetId", &target_id))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment