fix: app.relaunch loses args when execPath specified (#35108)

This commit is contained in:
Aaron Meriwether 2022-08-08 01:12:06 -07:00 committed by GitHub
parent 34b985c556
commit 91f9436ad8
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 15 additions and 7 deletions

View file

@ -1151,7 +1151,9 @@ bool App::Relaunch(gin::Arguments* js_args) {
gin_helper::Dictionary options; gin_helper::Dictionary options;
if (js_args->GetNext(&options)) { if (js_args->GetNext(&options)) {
if (options.Get("execPath", &exec_path) || options.Get("args", &args)) bool has_exec_path = options.Get("execPath", &exec_path);
bool has_args = options.Get("args", &args);
if (has_exec_path || has_args)
override_argv = true; override_argv = true;
} }

View file

@ -370,9 +370,11 @@ describe('app module', () => {
server!.once('error', error => done(error)); server!.once('error', error => done(error));
server!.on('connection', client => { server!.on('connection', client => {
client.once('data', data => { client.once('data', data => {
if (String(data) === 'false' && state === 'none') { if (String(data) === '--first' && state === 'none') {
state = 'first-launch'; state = 'first-launch';
} else if (String(data) === 'true' && state === 'first-launch') { } else if (String(data) === '--second' && state === 'first-launch') {
state = 'second-launch';
} else if (String(data) === '--third' && state === 'second-launch') {
done(); done();
} else { } else {
done(`Unexpected state: "${state}", data: "${data}"`); done(`Unexpected state: "${state}", data: "${data}"`);
@ -381,7 +383,7 @@ describe('app module', () => {
}); });
const appPath = path.join(fixturesPath, 'api', 'relaunch'); const appPath = path.join(fixturesPath, 'api', 'relaunch');
const child = cp.spawn(process.execPath, [appPath]); const child = cp.spawn(process.execPath, [appPath, '--first']);
child.stdout.on('data', (c) => console.log(c.toString())); child.stdout.on('data', (c) => console.log(c.toString()));
child.stderr.on('data', (c) => console.log(c.toString())); child.stderr.on('data', (c) => console.log(c.toString()));
child.on('exit', (code, signal) => { child.on('exit', (code, signal) => {

View file

@ -11,11 +11,15 @@ app.whenReady().then(() => {
const lastArg = process.argv[process.argv.length - 1]; const lastArg = process.argv[process.argv.length - 1];
const client = net.connect(socketPath); const client = net.connect(socketPath);
client.once('connect', () => { client.once('connect', () => {
client.end(String(lastArg === '--second')); client.end(lastArg);
}); });
client.once('end', () => { client.once('end', () => {
if (lastArg !== '--second') { if (lastArg === '--first') {
app.relaunch({ args: process.argv.slice(1).concat('--second') }); // Once without execPath specified
app.relaunch({ args: process.argv.slice(1, -1).concat('--second') });
} else if (lastArg === '--second') {
// And once with execPath specified
app.relaunch({ execPath: process.argv[0], args: process.argv.slice(1, -1).concat('--third') });
} }
app.exit(0); app.exit(0);
}); });