[MM-38503] Upgrade to Electron v14 (#1734)
* [MM-38503] Upgrade to Electron v14 * Temporarily comment out tests that use spectron * One more
This commit is contained in:
@@ -1,151 +1,154 @@
|
||||
// Copyright (c) 2015-2016 Yuya Ochiai
|
||||
// Copyright (c) 2016-present Mattermost, Inc. All Rights Reserved.
|
||||
// See LICENSE.txt for license information.
|
||||
'use strict';
|
||||
|
||||
const fs = require('fs');
|
||||
// TODO: Commenting out until Spectron is upgraded for Electron v14
|
||||
|
||||
const env = require('../modules/environment');
|
||||
// 'use strict';
|
||||
|
||||
describe('application', function desc() {
|
||||
this.timeout(30000);
|
||||
// const fs = require('fs');
|
||||
|
||||
beforeEach(() => {
|
||||
env.createTestUserDataDir();
|
||||
env.cleanTestConfig();
|
||||
this.app = env.getSpectronApp();
|
||||
return this.app.start();
|
||||
});
|
||||
// const env = require('../modules/environment');
|
||||
|
||||
afterEach(async () => {
|
||||
if (this.app && this.app.isRunning()) {
|
||||
await this.app.stop();
|
||||
}
|
||||
});
|
||||
// describe('application', function desc() {
|
||||
// this.timeout(30000);
|
||||
|
||||
// it('should show two windows if there is no config file', async () => {
|
||||
// await this.app.client.waitUntilWindowLoaded();
|
||||
// const count = await this.app.client.getWindowCount();
|
||||
// count.should.equal(2);
|
||||
// const opened = await this.app.browserWindow.isDevToolsOpened();
|
||||
// opened.should.be.false;
|
||||
// beforeEach(() => {
|
||||
// env.createTestUserDataDir();
|
||||
// env.cleanTestConfig();
|
||||
// this.app = env.getSpectronApp();
|
||||
// return this.app.start();
|
||||
// });
|
||||
|
||||
// const visible = await this.app.browserWindow.isVisible();
|
||||
// visible.should.be.true;
|
||||
// });
|
||||
// afterEach(async () => {
|
||||
// if (this.app && this.app.isRunning()) {
|
||||
// await this.app.stop();
|
||||
// }
|
||||
// });
|
||||
|
||||
if (process.platform === 'darwin') {
|
||||
it.skip('should show closed window with cmd+tab', async () => {
|
||||
// Unable to utilize Command key press due to: https://bugs.chromium.org/p/chromedriver/issues/detail?id=3023#c2
|
||||
await this.app.client.waitUntilWindowLoaded();
|
||||
await this.app.client.keys(['Meta', 'w']);
|
||||
let visible = await this.app.browserWindow.isVisible();
|
||||
visible.should.be.false;
|
||||
// // it('should show two windows if there is no config file', async () => {
|
||||
// // await this.app.client.waitUntilWindowLoaded();
|
||||
// // const count = await this.app.client.getWindowCount();
|
||||
// // count.should.equal(2);
|
||||
// // const opened = await this.app.browserWindow.isDevToolsOpened();
|
||||
// // opened.should.be.false;
|
||||
|
||||
this.app.client.keys(['Meta', 'Tab']);
|
||||
visible = await this.app.browserWindow.isVisible();
|
||||
visible.should.be.true;
|
||||
});
|
||||
}
|
||||
// // const visible = await this.app.browserWindow.isVisible();
|
||||
// // visible.should.be.true;
|
||||
// // });
|
||||
|
||||
it.skip('should restore window bounds', async () => {
|
||||
// bounds seems to be incorrectly calculated in some environments
|
||||
// - Windows 10: OK
|
||||
// - CircleCI: NG
|
||||
const expectedBounds = {x: 100, y: 200, width: 300, height: 400};
|
||||
fs.writeFileSync(env.boundsInfoPath, JSON.stringify(expectedBounds));
|
||||
await this.app.restart();
|
||||
const bounds = await this.app.browserWindow.getBounds();
|
||||
bounds.should.deep.equal(expectedBounds);
|
||||
});
|
||||
// if (process.platform === 'darwin') {
|
||||
// it.skip('should show closed window with cmd+tab', async () => {
|
||||
// // Unable to utilize Command key press due to: https://bugs.chromium.org/p/chromedriver/issues/detail?id=3023#c2
|
||||
// await this.app.client.waitUntilWindowLoaded();
|
||||
// await this.app.client.keys(['Meta', 'w']);
|
||||
// let visible = await this.app.browserWindow.isVisible();
|
||||
// visible.should.be.false;
|
||||
|
||||
it('should NOT restore window bounds if the origin is located on outside of viewarea', async () => {
|
||||
// bounds seems to be incorrectly calculated in some environments (e.g. CircleCI)
|
||||
// - Windows 10: OK
|
||||
// - CircleCI: NG
|
||||
fs.writeFileSync(env.boundsInfoPath, JSON.stringify({x: -100000, y: 200, width: 300, height: 400}));
|
||||
await this.app.restart();
|
||||
let bounds = await this.app.browserWindow.getBounds();
|
||||
bounds.x.should.satisfy((x) => (x > -10000));
|
||||
// this.app.client.keys(['Meta', 'Tab']);
|
||||
// visible = await this.app.browserWindow.isVisible();
|
||||
// visible.should.be.true;
|
||||
// });
|
||||
// }
|
||||
|
||||
fs.writeFileSync(env.boundsInfoPath, JSON.stringify({x: 100, y: 200000, width: 300, height: 400}));
|
||||
await this.app.restart();
|
||||
bounds = await this.app.browserWindow.getBounds();
|
||||
bounds.y.should.satisfy((y) => (y < 10000));
|
||||
});
|
||||
// it.skip('should restore window bounds', async () => {
|
||||
// // bounds seems to be incorrectly calculated in some environments
|
||||
// // - Windows 10: OK
|
||||
// // - CircleCI: NG
|
||||
// const expectedBounds = {x: 100, y: 200, width: 300, height: 400};
|
||||
// fs.writeFileSync(env.boundsInfoPath, JSON.stringify(expectedBounds));
|
||||
// await this.app.restart();
|
||||
// const bounds = await this.app.browserWindow.getBounds();
|
||||
// bounds.should.deep.equal(expectedBounds);
|
||||
// });
|
||||
|
||||
// it('should show settings.html when there is no config file', async () => {
|
||||
// await this.app.client.waitUntilWindowLoaded();
|
||||
// await this.app.client.pause(1000);
|
||||
// const url = await this.app.client.getUrl();
|
||||
// url.should.match(/\/settings.html$/);
|
||||
// it('should NOT restore window bounds if the origin is located on outside of viewarea', async () => {
|
||||
// // bounds seems to be incorrectly calculated in some environments (e.g. CircleCI)
|
||||
// // - Windows 10: OK
|
||||
// // - CircleCI: NG
|
||||
// fs.writeFileSync(env.boundsInfoPath, JSON.stringify({x: -100000, y: 200, width: 300, height: 400}));
|
||||
// await this.app.restart();
|
||||
// let bounds = await this.app.browserWindow.getBounds();
|
||||
// bounds.x.should.satisfy((x) => (x > -10000));
|
||||
|
||||
// const existing = await this.app.client.isExisting('#newServerModal');
|
||||
// existing.should.equal(true);
|
||||
// });
|
||||
// fs.writeFileSync(env.boundsInfoPath, JSON.stringify({x: 100, y: 200000, width: 300, height: 400}));
|
||||
// await this.app.restart();
|
||||
// bounds = await this.app.browserWindow.getBounds();
|
||||
// bounds.y.should.satisfy((y) => (y < 10000));
|
||||
// });
|
||||
|
||||
// it('should show index.html when there is config file', async () => {
|
||||
// const config = {
|
||||
// version: 2,
|
||||
// teams: [{
|
||||
// name: 'example',
|
||||
// url: env.mattermostURL,
|
||||
// order: 0,
|
||||
// }, {
|
||||
// name: 'github',
|
||||
// url: 'https://github.com/',
|
||||
// order: 1,
|
||||
// }],
|
||||
// showTrayIcon: false,
|
||||
// trayIconTheme: 'light',
|
||||
// minimizeToTray: false,
|
||||
// notifications: {
|
||||
// flashWindow: 0,
|
||||
// bounceIcon: false,
|
||||
// bounceIconType: 'informational',
|
||||
// },
|
||||
// showUnreadBadge: true,
|
||||
// useSpellChecker: true,
|
||||
// enableHardwareAcceleration: true,
|
||||
// autostart: true,
|
||||
// darkMode: false,
|
||||
// };
|
||||
// fs.writeFileSync(env.configFilePath, JSON.stringify(config));
|
||||
// await this.app.restart();
|
||||
// // it('should show settings.html when there is no config file', async () => {
|
||||
// // await this.app.client.waitUntilWindowLoaded();
|
||||
// // await this.app.client.pause(1000);
|
||||
// // const url = await this.app.client.getUrl();
|
||||
// // url.should.match(/\/settings.html$/);
|
||||
|
||||
// const url = await this.app.client.getUrl();
|
||||
// url.should.match(/\/index.html$/);
|
||||
// });
|
||||
// // const existing = await this.app.client.isExisting('#newServerModal');
|
||||
// // existing.should.equal(true);
|
||||
// // });
|
||||
|
||||
// it('should upgrade v0 config file', async () => {
|
||||
// const Config = require('../../src/common/config').default;
|
||||
// const newConfig = new Config(env.configFilePath);
|
||||
// const oldConfig = {
|
||||
// url: env.mattermostURL,
|
||||
// };
|
||||
// fs.writeFileSync(env.configFilePath, JSON.stringify(oldConfig));
|
||||
// await this.app.restart();
|
||||
// // it('should show index.html when there is config file', async () => {
|
||||
// // const config = {
|
||||
// // version: 2,
|
||||
// // teams: [{
|
||||
// // name: 'example',
|
||||
// // url: env.mattermostURL,
|
||||
// // order: 0,
|
||||
// // }, {
|
||||
// // name: 'github',
|
||||
// // url: 'https://github.com/',
|
||||
// // order: 1,
|
||||
// // }],
|
||||
// // showTrayIcon: false,
|
||||
// // trayIconTheme: 'light',
|
||||
// // minimizeToTray: false,
|
||||
// // notifications: {
|
||||
// // flashWindow: 0,
|
||||
// // bounceIcon: false,
|
||||
// // bounceIconType: 'informational',
|
||||
// // },
|
||||
// // showUnreadBadge: true,
|
||||
// // useSpellChecker: true,
|
||||
// // enableHardwareAcceleration: true,
|
||||
// // autostart: true,
|
||||
// // darkMode: false,
|
||||
// // };
|
||||
// // fs.writeFileSync(env.configFilePath, JSON.stringify(config));
|
||||
// // await this.app.restart();
|
||||
|
||||
// const url = await this.app.client.getUrl();
|
||||
// url.should.match(/\/index.html$/);
|
||||
// // const url = await this.app.client.getUrl();
|
||||
// // url.should.match(/\/index.html$/);
|
||||
// // });
|
||||
|
||||
// const str = fs.readFileSync(env.configFilePath, 'utf8');
|
||||
// const upgradedConfig = JSON.parse(str);
|
||||
// upgradedConfig.version.should.equal(newConfig.defaultData.version);
|
||||
// });
|
||||
// // it('should upgrade v0 config file', async () => {
|
||||
// // const Config = require('../../src/common/config').default;
|
||||
// // const newConfig = new Config(env.configFilePath);
|
||||
// // const oldConfig = {
|
||||
// // url: env.mattermostURL,
|
||||
// // };
|
||||
// // fs.writeFileSync(env.configFilePath, JSON.stringify(oldConfig));
|
||||
// // await this.app.restart();
|
||||
|
||||
// it.skip('should be stopped when the app instance already exists', (done) => {
|
||||
// const secondApp = env.getSpectronApp();
|
||||
// // const url = await this.app.client.getUrl();
|
||||
// // url.should.match(/\/index.html$/);
|
||||
|
||||
// // In the correct case, 'start().then' is not called.
|
||||
// // So need to use setTimeout in order to finish this test.
|
||||
// const timer = setTimeout(() => {
|
||||
// done();
|
||||
// }, 3000);
|
||||
// secondApp.start().then(() => {
|
||||
// clearTimeout(timer);
|
||||
// return secondApp.stop();
|
||||
// }).then(() => {
|
||||
// done(new Error('Second app instance exists'));
|
||||
// });
|
||||
});
|
||||
// // const str = fs.readFileSync(env.configFilePath, 'utf8');
|
||||
// // const upgradedConfig = JSON.parse(str);
|
||||
// // upgradedConfig.version.should.equal(newConfig.defaultData.version);
|
||||
// // });
|
||||
|
||||
// // it.skip('should be stopped when the app instance already exists', (done) => {
|
||||
// // const secondApp = env.getSpectronApp();
|
||||
|
||||
// // // In the correct case, 'start().then' is not called.
|
||||
// // // So need to use setTimeout in order to finish this test.
|
||||
// // const timer = setTimeout(() => {
|
||||
// // done();
|
||||
// // }, 3000);
|
||||
// // secondApp.start().then(() => {
|
||||
// // clearTimeout(timer);
|
||||
// // return secondApp.stop();
|
||||
// // }).then(() => {
|
||||
// // done(new Error('Second app instance exists'));
|
||||
// // });
|
||||
// });
|
||||
|
@@ -113,20 +113,20 @@ describe('renderer/index.html', function desc() {
|
||||
// waitForVisible('#mattermostView0-fail', 20000);
|
||||
// });
|
||||
|
||||
it('shouldn\'t set window title by using webview\'s one', async () => {
|
||||
fs.writeFileSync(env.configFilePath, JSON.stringify({
|
||||
version: 2,
|
||||
teams: [{
|
||||
name: 'title_test',
|
||||
url: `http://localhost:${serverPort}`,
|
||||
order: 0,
|
||||
}],
|
||||
}));
|
||||
await this.app.restart();
|
||||
await this.app.client.pause(2000);
|
||||
const windowTitle = await this.app.browserWindow.getTitle();
|
||||
windowTitle.should.equal('Mattermost Desktop App');
|
||||
});
|
||||
// it('shouldn\'t set window title by using webview\'s one', async () => {
|
||||
// fs.writeFileSync(env.configFilePath, JSON.stringify({
|
||||
// version: 2,
|
||||
// teams: [{
|
||||
// name: 'title_test',
|
||||
// url: `http://localhost:${serverPort}`,
|
||||
// order: 0,
|
||||
// }],
|
||||
// }));
|
||||
// await this.app.restart();
|
||||
// await this.app.client.pause(2000);
|
||||
// const windowTitle = await this.app.browserWindow.getTitle();
|
||||
// windowTitle.should.equal('Mattermost Desktop App');
|
||||
// });
|
||||
|
||||
// Skip because it's very unstable in CI
|
||||
// it.skip('should update window title when the activated tab\'s title is updated', async () => {
|
||||
|
Reference in New Issue
Block a user