Branch: refs/heads/main
  Home:   https://github.com/WebKit/WebKit
  Commit: 957351991fb188e33f1e5c49671ae7819ad8937f
      
https://github.com/WebKit/WebKit/commit/957351991fb188e33f1e5c49671ae7819ad8937f
  Author: Anthony Tarbinian <[email protected]>
  Date:   2026-01-12 (Mon, 12 Jan 2026)

  Changed paths:
    M Source/WebKit/UIProcess/BrowsingContextGroup.cpp
    M Source/WebKit/UIProcess/BrowsingContextGroup.h
    M Source/WebKit/UIProcess/FrameProcess.cpp
    M Source/WebKit/UIProcess/FrameProcess.h
    M Source/WebKit/UIProcess/WebPageProxy.cpp
    M Tools/TestWebKitAPI/Tests/WebKitCocoa/SiteIsolation.mm

  Log Message:
  -----------
  [Site Isolation] Fix TestWebKitAPI.SiteIsolation.OpenBeforeInitialLoad
https://bugs.webkit.org/show_bug.cgi?id=300844
https://rdar.apple.com/162728352

Reviewed by Sihui Liu.

When navigation re-uses the source process and navigation is
going to a site which is different than the process's previous
site, don't inject browsing context into the process.

A similar call to ensureProcessForSite existed in
WebPageProxy::didCommitLoadForFrame. This is now moved to occur
in continueWithProcessForNavigation.

This patch also adds 
BrowsingContextGroup::addFrameProcessWithoutInjectingPageContext
which updates BrowsingContextGroup's site -> process map even when
we don't want to inject browsing context into the process.

Also changes BrowsingContextGroup::InjectBrowsingContextIntoProcess to
BrowsingContextGroupUpdate which describes the following cases:
- None: don't modify BrowsingContextGroup
- AddProcess: only update m_processMap with the site->process mapping
- AddProcessAndInjectBrowsingContext: do the same as AddProcess
        but also inject browsing context

Fixes API test SiteIsolation.OpenBeforeInitialLoad.

Test: Tools/TestWebKitAPI/Tests/WebKitCocoa/SiteIsolation.mm

* Source/WebKit/UIProcess/BrowsingContextGroup.cpp:
(WebKit::BrowsingContextGroup::sharedProcessForSite):
(WebKit::BrowsingContextGroup::ensureProcessForSite):
(WebKit::BrowsingContextGroup::addFrameProcessAndInjectPageContextIf):
(WebKit::BrowsingContextGroup::addFrameProcessWithoutInjectingPageContext):
* Source/WebKit/UIProcess/BrowsingContextGroup.h:
* Source/WebKit/UIProcess/FrameProcess.cpp:
(WebKit::FrameProcess::FrameProcess):
* Source/WebKit/UIProcess/FrameProcess.h:
(WebKit::FrameProcess::create):
* Source/WebKit/UIProcess/WebPageProxy.cpp:
(WebKit::WebPageProxy::receivedNavigationActionPolicyDecision):
(WebKit::WebPageProxy::continueNavigationInNewProcess):
(WebKit::WebPageProxy::didCommitLoadForFrame):
* Tools/TestWebKitAPI/Tests/WebKitCocoa/SiteIsolation.mm:
(TestWebKitAPI::TEST(SiteIsolation, OpenBeforeInitialLoad)):

Canonical link: https://commits.webkit.org/305486@main



To unsubscribe from these emails, change your notification settings at 
https://github.com/WebKit/WebKit/settings/notifications

Reply via email to