fix: ensure nativeImage serialization main->renderer (#23759)
This commit is contained in:
parent
e5da2caa34
commit
e8ea007104
3 changed files with 41 additions and 8 deletions
|
@ -366,11 +366,11 @@ ifdescribe(features.isRemoteModuleEnabled())('remote module', () => {
|
|||
const w = makeWindow();
|
||||
const remotely = makeRemotely(w);
|
||||
|
||||
it('can serialize an empty nativeImage', async () => {
|
||||
const getEmptyImage = (img: NativeImage) => img.isEmpty();
|
||||
it('can serialize an empty nativeImage from renderer to main', async () => {
|
||||
const getImageEmpty = (img: NativeImage) => img.isEmpty();
|
||||
|
||||
w().webContents.once('remote-get-global', (event) => {
|
||||
event.returnValue = getEmptyImage;
|
||||
event.returnValue = getImageEmpty;
|
||||
});
|
||||
|
||||
await expect(remotely(() => {
|
||||
|
@ -379,11 +379,23 @@ ifdescribe(features.isRemoteModuleEnabled())('remote module', () => {
|
|||
})).to.eventually.be.true();
|
||||
});
|
||||
|
||||
it('can serialize a non-empty nativeImage', async () => {
|
||||
const getNonEmptyImage = (img: NativeImage) => img.getSize();
|
||||
it('can serialize an empty nativeImage from main to renderer', async () => {
|
||||
w().webContents.once('remote-get-global', (event) => {
|
||||
const emptyImage = require('electron').nativeImage.createEmpty();
|
||||
event.returnValue = emptyImage;
|
||||
});
|
||||
|
||||
await expect(remotely(() => {
|
||||
const image = require('electron').remote.getGlobal('someFunction');
|
||||
return image.isEmpty();
|
||||
})).to.eventually.be.true();
|
||||
});
|
||||
|
||||
it('can serialize a non-empty nativeImage from renderer to main', async () => {
|
||||
const getImageSize = (img: NativeImage) => img.getSize();
|
||||
|
||||
w().webContents.once('remote-get-global', (event) => {
|
||||
event.returnValue = getNonEmptyImage;
|
||||
event.returnValue = getImageSize;
|
||||
});
|
||||
|
||||
await expect(remotely(() => {
|
||||
|
@ -393,6 +405,18 @@ ifdescribe(features.isRemoteModuleEnabled())('remote module', () => {
|
|||
})).to.eventually.deep.equal({ width: 2, height: 2 });
|
||||
});
|
||||
|
||||
it('can serialize a non-empty nativeImage from main to renderer', async () => {
|
||||
w().webContents.once('remote-get-global', (event) => {
|
||||
const nonEmptyImage = nativeImage.createFromDataURL('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAACCAIAAAD91JpzAAAAFklEQVQYlWP8//8/AwMDEwMDAwMDAwAkBgMBBMzldwAAAABJRU5ErkJggg==');
|
||||
event.returnValue = nonEmptyImage;
|
||||
});
|
||||
|
||||
await expect(remotely(() => {
|
||||
const image = require('electron').remote.getGlobal('someFunction');
|
||||
return image.getSize();
|
||||
})).to.eventually.deep.equal({ width: 2, height: 2 });
|
||||
});
|
||||
|
||||
it('can properly create a menu with an nativeImage icon in the renderer', async () => {
|
||||
await expect(remotely(() => {
|
||||
const { remote, nativeImage } = require('electron');
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue