electron/spec-main
Samuel Attard 78411db4b5
fix: maintain a ref count for objects sent over remote (#17464)
* spec: clean up after a failed window count assertion

Previously when this assertion failed all tests that ran after the
failed assertion also failed.  This ensure that the assertion fails for
the test that actually caused the issue but cleans up the left-over
windows so that future tests do not fail.

* fix: maintain a ref count for objects sent over remote

Previously there was a race condition where a GC could occur in the
renderer process between the main process sending a meta.id and the
renderer pulling the proxy out its weakmap to stop it being GC'ed.

This fixes that race condition by maintaining a "sent" ref count in the
object registry and a "received" ref count in the object cache on the
renderer side.  The deref request now sends the number of refs the
renderer thinks it owns, if the number does not match the value in the
object registry it is assumed that there is an IPC message containing a
new reference in flight and this race condition was hit.

The browser side ref count is then reduced and we wait for the new deref
message.  This guaruntees that an object will only be removed from the
registry if every reference we sent has been guarunteed to be unreffed.
2019-04-16 16:08:11 -04:00
..
.eslintrc spec: initial spike of main-process based tests 2019-03-14 12:50:06 -07:00
.gitignore spec: add tests for the autoUpdater on macOS that actually test if it works (#17442) 2019-03-29 17:32:52 -07:00
ambient.d.ts spec: initial spike of main-process based tests 2019-03-14 12:50:06 -07:00
api-app-spec.ts refactor: make accessibilitySupportEnabled a property on app (#17362) 2019-04-04 19:49:04 -07:00
api-autoupdater-darwin-spec.ts spec: add tests for the autoUpdater on macOS that actually test if it works (#17442) 2019-03-29 17:32:52 -07:00
api-web-contents-spec.ts test: de-flake getAllWebContents test by moving it to spec-main (#17610) 2019-04-01 18:28:11 -07:00
events-helpers.ts spec: initial spike of main-process based tests 2019-03-14 12:50:06 -07:00
index.js build: fix spec-main linting for 'only' (#17666) 2019-04-03 11:19:39 -07:00
package.json spec: initial spike of main-process based tests 2019-03-14 12:50:06 -07:00
window-helpers.ts fix: maintain a ref count for objects sent over remote (#17464) 2019-04-16 16:08:11 -04:00