mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-06-05 21:39:12 +02:00
chrome: Update expectations with same-site BFCache enabled (fixes issue #3301)
With same-site BFCache enabled every navigation can now potentially be served via the BFCache. To support this internally a new top-level RenderFrame object may be created for each new navigation. As a result, OnBrowserCreated may now be called multiple times with the same browser ID in a given renderer process (a behavior previously only seen with cross-site navigations and different renderer processes). BFCache navigations do not trigger the same Chromium notifications as a normal load. To avoid breaking CEF API usage expectations we now synthetically generate the load-related callbacks that would otherwise be missing (OnLoadingStateChange with isLoading=true, OnLoadStart, OnLoadEnd). The |httpStatusCode| argument to OnLoadEnd will be 0 in this case. To test: - Run `FrameHandlerTest.*:MessageRouterTest.*:NavigationTest.*` - Run `NavigationTest.LoadSameOriginLoadURL` for OnBrowserCreated behavior. - Run `NavigationTest.History` for load-related callback behavior.
This commit is contained in:
@ -13,6 +13,7 @@
|
||||
|
||||
#include "include/internal/cef_types.h"
|
||||
|
||||
#include "third_party/blink/public/mojom/frame/lifecycle.mojom-blink-forward.h"
|
||||
#include "third_party/blink/public/platform/web_common.h"
|
||||
#include "v8/include/v8.h"
|
||||
|
||||
@ -72,6 +73,32 @@ BLINK_EXPORT v8::Local<v8::Value> ExecuteV8ScriptAndReturnValue(
|
||||
|
||||
BLINK_EXPORT bool IsScriptForbidden();
|
||||
|
||||
class BLINK_EXPORT CefObserverRegistration {
|
||||
public:
|
||||
CefObserverRegistration() = default;
|
||||
|
||||
CefObserverRegistration(const CefObserverRegistration&) = delete;
|
||||
CefObserverRegistration& operator=(const CefObserverRegistration&) = delete;
|
||||
|
||||
virtual ~CefObserverRegistration() = default;
|
||||
};
|
||||
|
||||
class BLINK_EXPORT CefExecutionContextLifecycleStateObserver {
|
||||
public:
|
||||
virtual void ContextLifecycleStateChanged(
|
||||
blink::mojom::blink::FrameLifecycleState state) {}
|
||||
|
||||
protected:
|
||||
virtual ~CefExecutionContextLifecycleStateObserver() = default;
|
||||
};
|
||||
|
||||
// Register an ExecutionContextLifecycleStateObserver. Remains registered until
|
||||
// the returned object is destroyed.
|
||||
BLINK_EXPORT std::unique_ptr<CefObserverRegistration>
|
||||
RegisterExecutionContextLifecycleStateObserver(
|
||||
v8::Local<v8::Context> context,
|
||||
CefExecutionContextLifecycleStateObserver* observer);
|
||||
|
||||
BLINK_EXPORT void RegisterURLSchemeAsSupportingFetchAPI(
|
||||
const blink::WebString& scheme);
|
||||
|
||||
|
Reference in New Issue
Block a user