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

Start crash reporter inside child processes #27180

Merged
merged 3 commits into from
May 25, 2017
Merged

Conversation

ramya-rao-a
Copy link
Contributor

@ramya-rao-a ramya-rao-a commented May 24, 2017

Starting the crash reporter for the extension host
Related to #21944

If this works as expected, we can do the same for the rest of the child processes that we spawn/fork and need crash reporting

@mention-bot
Copy link

@ramya-rao-a, thanks for your PR! By analyzing the history of the files in this pull request, we identified @Tyriar and @joaomoreno to be potential reviewers.

@ramya-rao-a ramya-rao-a force-pushed the ramyar/crash-report branch from 59fa62c to b4dfa37 Compare May 24, 2017 06:43
@ramya-rao-a ramya-rao-a requested a review from bpasero May 24, 2017 06:44
@ramya-rao-a ramya-rao-a self-assigned this May 24, 2017
@bpasero
Copy link
Member

bpasero commented May 24, 2017

@ramya-rao-a I suggest to just introduce process.env variables for the crash reporter metadata and read them in the forked process. Using the local storage as a way to communicate data is a bad hack. At the very minimum it should be a ICrashReporterService that we can require in places where we need it (except for forked processes where we do not have services). Anyway, using process environment would save you that issue as well as you would not have to pass arguments around.

We still only have one crash reporter process even when we start it from other processes, right?

@ramya-rao-a
Copy link
Contributor Author

@bpasero

Using the local storage as a way to communicate data is a bad hack

Will look into creating ICrashReporterService which can have 2 methods. One to get the args another to start the crash reporter

We still only have one crash reporter process even when we start it from other processes, right?

In Mac which uses crashpad yes. There is a single handler for monitoring crashes for all processes (main, renderer, child)

In Windows, we need start another process that does the monitoring. This PR doesn't include that. See https://github.com/electron/electron/blob/master/docs/api/crash-reporter.md#crashreporterstartoptions

I'll have to dig a little more to get the more details

@bpasero
Copy link
Member

bpasero commented May 24, 2017

@ramya-rao-a what we could also do as a starter is to only enable this on macOS for e.g. the extension host.

@ramya-rao-a ramya-rao-a force-pushed the ramyar/crash-report branch from b4dfa37 to 7fa1ff4 Compare May 24, 2017 23:46
@ramya-rao-a
Copy link
Contributor Author

@bpasero PR updated as we discussed

@bpasero
Copy link
Member

bpasero commented May 25, 2017

@ramya-rao-a I pushed some refactorings and a bugfixes on top of your commit to this PR, please have a look. When trying this out locally I was getting a crash right on startup on the extension host.

One thing to look into is your use of crashesDirectory. Shouldn't this property be set on the crash reporter options directly and not the extra bag? And then, we should probably not set this option all the time but only from the object returned from getChildProcessStartOptions

From the documentation at https://github.com/electron/electron/blob/master/docs/api/crash-reporter.md#crashreporterstartoptions it was not clear to me how crashesDirectory has to be used...

@ramya-rao-a
Copy link
Contributor Author

@bpasero

crash right on startup on the extension host

Ah! This was due to the object being passed and not the stringified object. That was a last minute change I made as an after thought, but didn't test. Sorry, my bad.

crashesDirectory on the crash reporter options directly and not the extra bag

Yes, this should be part of the main payload and not the extra bag. Fixed with 95c8517

we should probably not set this option all the time but only from the object returned from getChildProcessStartOptions

Ideally yes. This option is not used by the main/renderer process, so I didn't see the harm in sending it all the time rather than just for the child process. Fixed with 95c8517

btw I spent a lot of time getting the service plumbing to work, but kept getting unhelpful errors while instantiating the ExtensionHostProcessWorker which I then narrowed down to my service not defining "_serviceBrand". Do we have any docs around do's don'ts for such cases?

Copy link
Member

@bpasero bpasero left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@ramya-rao-a looks good now 👍

@ramya-rao-a ramya-rao-a merged commit 391f742 into master May 25, 2017
@bpasero bpasero deleted the ramyar/crash-report branch May 26, 2017 05:55
dbaeumer pushed a commit that referenced this pull request May 26, 2017
* Use service to get crash reporter start options

* some refactorings and fixes

* Move crashesDirectory to the main payload from extra bag
@github-actions github-actions bot locked and limited conversation to collaborators Mar 27, 2020
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants