Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Error while fulfilling of JS: Request BrowserId : 1 not found it's likely the browser is already closed #4621

Open
1 task done
maksimrudn opened this issue Nov 1, 2023 · 53 comments
Labels
upstream These issues require fixing in the Chromium Embedded Framework(CEF) or Chromium.
Milestone

Comments

@maksimrudn
Copy link

maksimrudn commented Nov 1, 2023

Is there an existing issue for this?

  • I have searched both open/closed issues, no issue already exists.

CefSharp Version

117.2.40

Operating System

Windows 10

Architecture

x64

.Net Version

.net 6.0

Implementation

OffScreen

Reproduction Steps

Version: Above 108

Steps:
Create instance of CefSharp.OffScreen.ChromiumWebBrowser
br = CefSharp.OffScreen.ChromiumWebBrowser();

Go by url 2 times:
br.Load(url)
await br.EvaluateScriptAsPromiseAsync(script);
br.Load(url)
await br.GetSourceAsync();
br.Load(url)

Fulfill JS
_browser.EvaluateScriptAsPromiseAsync(script)

Expected behavior

Fulfilling of JS

Actual behavior

JS Error Request BrowserId : 1 not found it's likely the browser is already closed

Regression?

After regression to version 108 problem dissapeared.

Known Workarounds

Likely problem is here
https://github.com/cefsharp/CefSharp/blob/master/CefSharp.BrowserSubprocess.Core/CefAppUnmanagedWrapper.cpp
Look at history..

Does this problem also occur in the CEF Sample Application

Yes using WPF/OffScreen command line args

Other information

No response

@amaitland

This comment was marked as outdated.

@maksimrudn

This comment was marked as off-topic.

@amaitland

This comment was marked as outdated.

@amaitland

This comment was marked as outdated.

@daveime68

This comment was marked as off-topic.

@ficho-hun
Copy link

ficho-hun commented Jan 9, 2024

It seems that happening with only some Websites.
I enabled the CEF logging, maybe can you find here something.

cef.log

@netmaxik
Copy link

netmaxik commented Feb 1, 2024

good day @amaitland
I did https://github.com/netmaxik/CefSharp.MinimalExample.netcore special.
Use WPF project and press Test button. On title you will see Elements under mouse. Press Test again to stop. After you go to : https://accounts.google.com/?hl=en, wait to load and press test again you see that error appears . For me last version where it was work correctly was : 112.3.0 After that i got that error everywhere.

@nebojsasandin
Copy link

@netmaxik have you tried the new v121.3.x ? Has the issue been resolved @amaitland ?
I'm experiencing the same problem @netmaxik is, basically anything related to Google (google drive, docs, gmail, accounts, etc...) is broken on all versions past 112.3.0. Haven't tested v121.3.x though.

@amaitland

This comment was marked as outdated.

@nebojsasandin

This comment was marked as outdated.

@amaitland

This comment was marked as outdated.

nebojsasandin added a commit to nebojsasandin/CefSharp that referenced this issue Mar 3, 2024
Modified Google test to replicate this issue: cefsharp#4621
@nebojsasandin
Copy link

Not sure if this was what I was supposed to do (I've never done this before), but I forked the entire master branch, changed the offscreen test cs file, included the part which causes an exception, and initialized pull request on this one single file from my fork: #4741

I could not get it to compile or run though, there was a whole bunch of errors in the C++ sources which I'm unfamiliar with, so I could not see if the test truly replicates the issue described here, but I did test it in async fashion as well in the original test I sent you, and it did produce the same exception, so hopefully you'll be able to replicate the issue on your end and see what's causing it in the first place, so we can get this resolved.

Thank you.

nebojsasandin added a commit to nebojsasandin/CefSharp that referenced this issue Mar 9, 2024
@amaitland
Copy link
Member

amaitland commented Mar 24, 2024

initialized pull request on this one single file from my fork: #4741

For the example provided by @nebojsasandin you can forcibly isolate the origins and the script executes correctly.

settings.CefCommandLineArgs.Add("isolate-origins", "https://accounts.google.com,https://chrome.google.com,https://chromewebstore.google.com");

@amaitland
Copy link
Member

Loading chrome://process-internals/#site-isolation in Chrome I see

image

In the CEF Sample Application (cefclient) it looks like

image

So CEF doesn't have the same google urls isolated like Chrome does.

You can add the following command line arg to mimic the Chrome behaviour.

settings.CefCommandLineArgs.Add("isolate-origins", "https://accounts.google.com,https://chrome.google.com,https://chromewebstore.google.com");

@amaitland
Copy link
Member

I've created chromiumembedded/cef#3672 to see if CEF can set the built-in isolations by default.

Until then you can use the workaround I've listed above.

It seems that happening with only some Websites.

@ficho-hun Did you observe the issue on websites other than the google ones?

After you go to : https://accounts.google.com/?hl=en,

@netmaxik If you are still experiencing this issue then please test with the workaround provided in #4621 (comment)

@netmaxik
Copy link

@amaitland I did test with : settings.CefCommandLineArgs.Add("isolate-origins", "https://accounts.google.com,https://chrome.google.com,https://chromewebstore.google.com");.

What I found out is :

  1. If I start application - press Test button - then press Sign In or went to https://accounts.google.com/?hl=en, - I got problem. same error. BUT
  2. If I start application - DO not press Test and press Sign In to google or https://accounts.google.com/?hl=en - then press test - its working normally.

@amaitland
Copy link
Member

@netmaxik If you create a failing Unit test and create a PR then I will have a look. You can use #4741 as a reference for creating a test.

@amaitland amaitland added the upstream These issues require fixing in the Chromium Embedded Framework(CEF) or Chromium. label Mar 25, 2024
@nebojsasandin
Copy link

nebojsasandin commented Mar 26, 2024

@netmaxik Have you tried adding more domains to the list? In my use-case I had to add few extra domains:
https://accounts.google.com,https://chrome.google.com,https://chromewebstore.google.com,https://reportcontent.google.com,https://support.google.com,https://www.google.com
It would be good if we could do: *.google.com to cover all of google's sub-domains, but it appears that "isolate-origins" setting is not that versatile.
@amaitland , it seems that the CEF staff don't recognize this as a bug, or anything that needs to be changed, however, this does break the functionality of the CefSharp. Is there a more permanent or future-proof solution other than knowing which domains are breaking this entire facility? What if there is another domain (other than Google) which also breaks JavaScript in CefSharp, but in order to capture it - one would have to know the domain name.

@netmaxik
Copy link

netmaxik commented Mar 27, 2024

@nebojsasandin I did most off them.. nothing help. I do not know how to create test units... so do not know my next steps. But issue still continue :(.

@amaitland Im sorry I cannot create Test Units. I did not know how to do that. :( And now really do not have time to learn and understand that :( really sorry..

nebojsasandin added a commit to nebojsasandin/CefSharp that referenced this issue Mar 27, 2024
New test to mimic issue cefsharp#4621 where isolate-origins settings does not help.
@nebojsasandin
Copy link

nebojsasandin commented Mar 27, 2024

@netmaxik , when I test your code based on the instructions you provided (click on Test button, then navigate to Sign In, it still works when I include "https://www.google.com" to the isolate-origins).

[EDIT] - turns out you can do this: https://[*.].google.com but still, the error persists when one tries to switch from Google to Gmail.

...However, I realized that there are still issues with this even with the workaround. So maybe that's what you're talking about.
@amaitland , I've created a new pull request: #4771 with the new method created, the one which demonstrates that "isolate-origins" which includes all domains being visited is still producing the same error.

[EDIT] - as a side-note, I did try: disable-web-security; disable-features=IsolateOrigins,site-per-process; disable-site-isolation-trials; and neither of these helped.

@amaitland amaitland added this to the 125.0.x milestone May 6, 2024
@amaitland
Copy link
Member

it seems that the CEF staff don't recognize this as a bug, or anything that needs to be changed, however, this does break the functionality of the CefSharp. Is there a more permanent or future-proof solution other than knowing which domains are breaking this entire facility?

The problem is in the Alloy Bootstrap, not something that can be fixed directly in CefSharp. The interesting news is that CEF is just started to remove the Alloy Boostrap (chromiumembedded/cef#3685) and has added support for using the Chrome Bootstrap with Alloy Style OSR windows.

Starting in M125 you'll be able to use CefSettings.ChromeRuntime = true and the same isolation settings a Chrome will be used.

I've added both tests (they'll only run locally, not on Appveyor) and migrated the CefSharp.Test project to using the ChromeRuntime. Both now pass without any changes or custom origin isolations.

In ~M127 the Alloy Bootstrap will be removed.

I've created a new pull request: #4771 with the new method created, the one which demonstrates that "isolate-origins" which includes all domains being visited is still producing the same error.

@nebojsasandin Thanks for providing the tests 👍 The problem is likely in the alloy bootstrap and should be resolved by switching to the Chrome bootstrap.

@amaitland
Copy link
Member

Well it seems to be fixed if you specifically set ChromeRuntime=false in your settings. At least this worked for me after upgrading, and everything seems to be working alright.

If the problem only occurs when using the Chrome Runtime then an upstream issue will need to be raised.

https://github.com/chromiumembedded/cef/issues

The alloy bootstrap will be removed in M128, you'll only be able to revert back for a short time.

I have also been experiencing the same issue with ChromeRuntime=true on random websites. It's not just related to Google websites.

I found it on: https://www.visualcom.pl/kontakt/wymagania-plikow-produkcyjnych'

@GrabzIt Can you please create a unit test that reproduces the problem you are seeing (and submit a PR).

There are already tests at

public class Issue4621
you can use those as a basis, just add another to the same class


To set expectations, I've not seen anything here that suggests this is an issue that can be fixed directly in CefSharp. If upstream changes are required then this will likely take some time to get fixed as reproducing the issue directly in C++ will be difficult.

I potential workaround would be to switch to using Chrome DevTools Protocol for executing javascript.

https://github.com/cefsharp/CefSharp.Dom?tab=readme-ov-file#dom-access


Hopefully at some point CEF will add equivalent functionality directly (chromiumembedded/cef#3631)

@GrabzIt
Copy link
Contributor

GrabzIt commented Jul 28, 2024

I have found that the errors happen after a long period of time, so hours or days, then carry on happening. So this isn't something that is suitable for a unit test.

I am going to try and use the Chrome DevTools Protocol to see if that fixes the issue.

@stormcleric
Copy link

I have found that the errors happen after a long period of time, so hours or days, then carry on happening. So this isn't something that is suitable for a unit test.

I am going to try and use the Chrome DevTools Protocol to see if that fixes the issue.

Not on my specific case - they were after 10 solid minutes - but it's funny it's time dependant.

@drRobertDev
Copy link

I have found that the errors happen after a long period of time, so hours or days, then carry on happening. So this isn't something that is suitable for a unit test.
I am going to try and use the Chrome DevTools Protocol to see if that fixes the issue.

Not on my specific case - they were after 10 solid minutes - but it's funny it's time dependant.

yes also to me afte 10 minutes, dont know why this timing. (rendering working, on paint work, just JS code dont work)

@nabkawe
Copy link

nabkawe commented Aug 12, 2024

I have found that the errors happen after a long period of time, so hours or days, then carry on happening. So this isn't something that is suitable for a unit test.
I am going to try and use the Chrome DevTools Protocol to see if that fixes the issue.

Not on my specific case - they were after 10 solid minutes - but it's funny it's time dependant.

I feel this is Google's way of breaking Chrome Extensions that need (JS level magic to do stuff like hide ads.)
I have the exact issue after upgrading from 112 to the latest stable nuget.

@nabkawe
Copy link

nabkawe commented Aug 12, 2024

EDIT: While this helped with the severity of the issue, it didn't actually solve it, I still have to naviage away and then back to the page I need

I had this error in another site, I "possibly" managed to fix it by turning off chromeruntime from the CefSharp Settings

` CefSharp.WinForms.CefSettings se = new CefSharp.WinForms.CefSettings();
se.CachePath = Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData) + @"\CEF";
se.EnablePrintPreview();
se.CefCommandLineArgs.Add("enable-media-stream");
se.JavascriptFlags = "--enable-media-stream";
se.JavascriptFlags = "--AllowRunningInsecureContent";
se.CefCommandLineArgs.Add("enable-usermedia-screen-capturing");
se.CefCommandLineArgs.Add("disable-site-isolation-trials"); // didn't work
se.ChromeRuntime = false; // worked instantly.
CefSharp.Cef.Initialize(se);

`

@onlylau
Copy link

onlylau commented Sep 30, 2024

Now they remove this "se.ChromeRuntime = false;" and i cant run my aplication! :\ start getting that error "Message = "Request BrowserId : 1 not found it's likely the browser is already closed""

@nuno84
Copy link

nuno84 commented Oct 3, 2024

Now they remove this "se.ChromeRuntime = false;" and i cant run my aplication! :\ start getting that error "Message = "Request BrowserId : 1 not found it's likely the browser is already closed""

I also have this issue. Did you find any workaround?
I am using CEF v128.4.90, it takes way less than 10 minutes and I amaccessing a common website but google related.

@onlylau
Copy link

onlylau commented Oct 4, 2024 via email

@amaitland
Copy link
Member

Please create a unit test inside the CefSharp.Test project and submit a PR.

There are already tests at

public class Issue4621
you can use those as a basis, just add another to the same class

Until there's a unit test that reproduces the problem there's not really anything actionable here.

@aimcosoftware
Copy link

aimcosoftware commented Nov 7, 2024

This is still an issue in 130.1.90.0 only when using EvaluateScriptAsync. ExecuteScriptAsync doesn't fail.
Only had this issue since Chrome bootstrap, all Alloy versions since 106 have worked.

Steps
Navigate to a page. On FrameLoadEnd, inject some DOM altering script , I'm using:

for(elm of document.body.getElementsByTagName("div")){ elm.style.border = "1px solid red" }
Navigate to other pages, within 4-6 pages, you'll get the error.

CEFSharp is entirely broken with this change, happy to provide any assistance to track it down.

@nuno84
Copy link

nuno84 commented Nov 7, 2024

But from what I understand, ExecuteScriptAsync doesn't return any data, and I need to get data from the browser. If I am right, than I cannot use that alternative.
Thank you for any suggestions.

@aimcosoftware
Copy link

aimcosoftware commented Nov 7, 2024

@nuno84 ExecuteScriptAsync doesn't return any data. I only mentioned it because it works, where EvaluateScriptAsync does not.
The page size seems to make a difference, I'm testing with these pages, they often fail on the 1st or 2nd navigate.

@amaitland
Copy link
Member

The page size seems to make a difference, I'm testing with these pages, they often fail on the 1st or 2nd navigate.

@aimcosoftware Can you turn that into a XUnit test as per #4621 (comment)

I need a reliable way to reproduce the problem.

@mahelm
Copy link

mahelm commented Nov 25, 2024

Edit: The problem below does not appear if the two apps are hosted on different sites (and http://localhost:4200 and http://localhost:4201 are considered to be the same site according to https://www.chromium.org/Home/chromium-security/site-isolation/). To have it working as expected I access one app with localhost and the other using the hostname. This helped me get on for now until its is fixed in CEFSharp.

---Originial post---

I am experiencing this issue as well and I though I'd share my context here in case it could be of any help in finding a way to fix or mitigate the problem. In my case I run EvaluateScriptAsync on IChromiumWebBrowserBase.FrameLoadEnd.
To reproduce the issue I have use two Angular applications, A and B, which are hosted on http://localhost:4200 and http://localhost:4201.

  • Load app A in the ChromiumWebBrowser => EvaluateScriptAsync success on site A
  • Navigate to app B via a link in app A => EvaluateScriptAsync success on site B
  • Navigate to app A via a link in app B => EvaluateScriptAsync failure with "Request BrowserId : 1 not found it's likely the browser is already closed"

I have tried with settings.CefCommandLineArgs.Add("isolate-origins", "http://localhost,https://accounts.google.com,https://chrome.google.com,https://chromewebstore.google.com"); but without any luck.

Version:
CefSharp.WinForms - 129.0.110

@amaitland
Copy link
Member

As above, I need more than just a list of steps to reproduce the problem, ideally a unit test, a fork of the minimal example would be ok I guess (would need to be turned into a unit test).

@mahelm
Copy link

mahelm commented Nov 26, 2024

As above, I need more than just a list of steps to reproduce the problem, ideally a unit test, a fork of the minimal example would be ok I guess (would need to be turned into a unit test).

The key seems to be that you need to have two web applications served from the same "site" (where site is the scheme and registered domain name, including the public suffix, but ignoring subdomains, port, or path). These could probably be simple html-pages with links to navigate between the apps. The CEFSharp application should just run EvaluateScriptAsync when a page is loaded. I don't know how to set up this as a unit test the code base unfortunately. I hope this helps.

@mitchcapper
Copy link
Contributor

mitchcapper commented Nov 26, 2024

Here is a pretty minimal example. Originally I used a totally non google set of urls that loaded more resources and would crash in 3 loads, but even just using some google.com pages it can happen for me at least in 5 ever time.

The code in short:

public MainWindow() {
	InitializeComponent();
	Loaded += MainWindow_Loaded;
}
private ChromiumWebBrowser browser;

private string theUrl = "https://google.com";
private string theUrl2 = "https://google.com/404";
private string theUrl3 = "https://google.com/503";
private async void MainWindow_Loaded(object sender, RoutedEventArgs e) {
	CefSharpSettings.RuntimeStyle = CefRuntimeStyle.Chrome;
	CefSettings settings = new() { CachePath = null, RootCachePath = @"x:\sandbox\test\trash_cache2", };
	Cef.Initialize(settings);
	browser = new ChromiumWebBrowser();
	contentCntrl.Content = browser;
	await Task.Delay(1000);

	await browser.NavigateTo(theUrl);
	var res = await browser.EvaluateScriptAsync<string>("5*6;");
	Log(res);
	await browser.NavigateTo(theUrl2);
	res = await browser.EvaluateScriptAsync<string>("5*6;");
	Log(res);
	
	await browser.NavigateTo(theUrl3);
	res = await browser.EvaluateScriptAsync<string>("5*6;");//original site generally throws here 
	Log(res);
	await browser.NavigateTo(theUrl2);
	res = await browser.EvaluateScriptAsync<string>("5*6;");
	Log(res);
	await browser.NavigateTo(theUrl);
	res = await browser.EvaluateScriptAsync<string>("5*6;");//for google sites throws here
	Log(res);
	await browser.NavigateTo(theUrl2);
	res = await browser.EvaluateScriptAsync<string>("5*6;");
	Log(res);

}

private void Log(string res) {
	Debug.WriteLine(res);
}
	}
public static class helpers {
	public static async Task NavigateTo(this ChromiumWebBrowser browser, String url) {
		browser.Address = url;
		await browser.WaitForNavigationAsync(TimeSpan.FromSeconds(30));
		await Task.Delay(1000);
	
	}
}

Full project:
cefEvalIssueBare.zip

@mitchcapper
Copy link
Contributor

It also doesn't need 3 urls just navigating from 1 to 2 and back to 1 generally works too.

@mitchcapper
Copy link
Contributor

mitchcapper commented Nov 26, 2024

I realize there is a lot of talk around google related domains so a shorter example using google domains probably wasnt the best bet. Here is something that is certainly not loading google:)

private string theUrl = "https://brave.com/";
private string theUrl2 = "https://brave.com/search/";
private async void MainWindow_Loaded(object sender, RoutedEventArgs e) {
	CefSharpSettings.RuntimeStyle = CefRuntimeStyle.Chrome;
	CefSettings settings = new() { CachePath = null, RootCachePath = @"x:\sandbox\test\trash_cache2", };
	Cef.Initialize(settings);
	contentCntrl.Content = browser = new ChromiumWebBrowser();
	await Task.Delay(1000);
	string res;
	for (var x = 0; x < 20; x++) {
		await browser.NavigateTo(x % 2 == 0 ? theUrl : theUrl2);
		res = await browser.EvaluateScriptAsync<string>($"{x}+1");
		Log(res);
	}
}

it can trigger it by the 8th load.

00:42:45:404	Step into: Stepping over non-user code 'cefEvalIssue.App.InitializeComponent'
00:42:49:401	1
00:42:50:658	2
00:42:51:902	3
00:42:53:151	4
00:42:54:149	5
00:42:55:401	6
00:42:56:650	7
00:42:57:962	Exception thrown: 'System.Exception' in CefSharp.Core.dll
00:42:57:962	Exception thrown: 'System.Exception' in System.Private.CoreLib.dll
00:42:57:962	An exception of type 'System.Exception' occurred in System.Private.CoreLib.dll but was not handled in user code
00:42:57:962	Request BrowserId : 1 not found it's likely the browser is already closed
00:42:57:962	

@amaitland
Copy link
Member

@mitchcapper Exactly what I needed, thank you!

public async Task NavigateBetweenTwoUrlsBreaksJs()
{
    const string theUrl = "https://brave.com/";
    const string theUrl2 = "https://brave.com/search/";

    using (var browser = new ChromiumWebBrowser(theUrl, useLegacyRenderHandler: false))
    {
        var response = await browser.WaitForInitialLoadAsync();

        await Task.Delay(1000);

        for (var x = 0; x < 20; x++)
        {
            await browser.LoadUrlAsync(x % 2 == 0 ? theUrl : theUrl2);

            var javascriptResponse = await browser.EvaluateScriptAsync($"{x}+1");

            Assert.True(javascriptResponse.Success, javascriptResponse.Message);

            Assert.Equal(x + 1, (int)javascriptResponse.Result);
        }
    }
}

@amaitland
Copy link
Member

Interestingly the NavigateBetweenTwoUrlsBreaksJs test passes if we disable the BF Cache.

settings.CefCommandLineArgs.Add("disable-back-forward-cache");

This is a very specific case, so not sure if that's going to work in other instances. It might be worth trying for some of you.

amaitland added a commit that referenced this issue Dec 7, 2024
@mahelm
Copy link

mahelm commented Dec 11, 2024

Interestingly the NavigateBetweenTwoUrlsBreaksJs test passes if we disable the BF Cache.

settings.CefCommandLineArgs.Add("disable-back-forward-cache");

This is a very specific case, so not sure if that's going to work in other instances. It might be worth trying for some of you.

Thanks! This fixes our issue at least!

@SASoper
Copy link

SASoper commented Jan 1, 2025

Wonderful! This has fixed this issue for me as well!

@ficho-hun
Copy link

For me, the error still exists. I load the URL only once, but the website's JavaScript script performs additional navigations.

@mitchcapper
Copy link
Contributor

@ficho-hun if you can put together a test case like amaitland's comment #4621 (comment)

likely to be responded far faster, especially now that many of us can't repro with that flag set.

@onlylau
Copy link

onlylau commented Jan 14, 2025

One of the things I noticed, is that I lose the debug of my javascript code,

Ex: Console.log("Finished")

When running the javascript in Visuastudio, nothing appears in the output.

@mitchcapper
Copy link
Contributor

One of the things I noticed, is that I lose the debug of my javascript code,

Ex: Console.log("Finished")

When running the javascript in Visuastudio, nothing appears in the output.

Under what conditions? Can you put a repro case together like above?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
upstream These issues require fixing in the Chromium Embedded Framework(CEF) or Chromium.
Projects
None yet
Development

No branches or pull requests