From 0650ffc7157eec7ebe6cb3f8a18bf04ee1555dca Mon Sep 17 00:00:00 2001 From: "trop[bot]" <37223003+trop[bot]@users.noreply.github.com> Date: Thu, 9 May 2024 12:33:21 -0400 Subject: [PATCH] fix: CHECK when adding view as its own child (#42107) Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com> Co-authored-by: Shelley Vohr --- shell/browser/api/electron_api_view.cc | 8 ++++++++ spec/api-view-spec.ts | 12 +++++++++++- 2 files changed, 19 insertions(+), 1 deletion(-) diff --git a/shell/browser/api/electron_api_view.cc b/shell/browser/api/electron_api_view.cc index eea9c8098ba..fb35345e095 100644 --- a/shell/browser/api/electron_api_view.cc +++ b/shell/browser/api/electron_api_view.cc @@ -189,6 +189,14 @@ void View::AddChildViewAt(gin::Handle child, // has a View, possibly a wrapper view around the underlying platform View. if (!view_) return; + + // This will CHECK and crash in View::AddChildViewAtImpl if not handled here. + if (view_ == child->view()) { + gin_helper::ErrorThrower(isolate()).ThrowError( + "A view cannot be added as its own child"); + return; + } + size_t index = std::min(child_views_.size(), maybe_index.value_or(child_views_.size())); child_views_.emplace(child_views_.begin() + index, // index diff --git a/spec/api-view-spec.ts b/spec/api-view-spec.ts index ada81800eab..020f3ce0d6a 100644 --- a/spec/api-view-spec.ts +++ b/spec/api-view-spec.ts @@ -1,3 +1,4 @@ +import { expect } from 'chai'; import { closeWindow } from './lib/window-helpers'; import { BaseWindow, View } from 'electron/main'; @@ -10,6 +11,15 @@ describe('View', () => { it('can be used as content view', () => { w = new BaseWindow({ show: false }); - w.setContentView(new View()); + const v = new View(); + w.setContentView(v); + expect(w.contentView).to.equal(v); + }); + + it('will throw when added as a child to itself', () => { + w = new BaseWindow({ show: false }); + expect(() => { + w.contentView.addChildView(w.contentView); + }).to.throw('A view cannot be added as its own child'); }); });