2021-11-19 07:21:34 -08:00
|
|
|
// Copyright (c) 2016-present Mattermost, Inc. All Rights Reserved.
|
|
|
|
// See LICENSE.txt for license information.
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const fs = require('fs');
|
|
|
|
|
|
|
|
const robot = require('robotjs');
|
|
|
|
|
|
|
|
const env = require('../../modules/environment');
|
|
|
|
const {asyncSleep} = require('../../modules/utils');
|
|
|
|
|
|
|
|
async function setupPromise(window, id) {
|
|
|
|
const promise = new Promise((resolve) => {
|
|
|
|
const browserView = window.getBrowserViews().find((view) => view.webContents.id === id);
|
|
|
|
browserView.webContents.on('did-finish-load', () => {
|
|
|
|
resolve();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
await promise;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
describe('mattermost', function desc() {
|
|
|
|
this.timeout(30000);
|
|
|
|
|
2022-01-17 07:20:11 -08:00
|
|
|
const config = env.demoMattermostConfig;
|
2021-11-19 07:21:34 -08:00
|
|
|
|
|
|
|
beforeEach(async () => {
|
|
|
|
env.cleanDataDir();
|
|
|
|
env.createTestUserDataDir();
|
|
|
|
env.cleanTestConfig();
|
|
|
|
fs.writeFileSync(env.configFilePath, JSON.stringify(config));
|
|
|
|
await asyncSleep(1000);
|
|
|
|
this.app = await env.getApp();
|
|
|
|
this.serverMap = await env.getServerMap(this.app);
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(async () => {
|
|
|
|
if (this.app) {
|
|
|
|
await this.app.close();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2022-01-17 07:20:11 -08:00
|
|
|
it('MM-T813 Control+F should focus the search bar in Mattermost', async () => {
|
2021-11-19 07:21:34 -08:00
|
|
|
const loadingScreen = this.app.windows().find((window) => window.url().includes('loadingScreen'));
|
|
|
|
await loadingScreen.waitForSelector('.LoadingScreen', {state: 'hidden'});
|
|
|
|
const firstServer = this.serverMap[`${config.teams[0].name}___TAB_MESSAGING`].win;
|
|
|
|
await env.loginToMattermost(firstServer);
|
|
|
|
await firstServer.waitForSelector('#searchBox');
|
2022-01-17 07:20:11 -08:00
|
|
|
robot.keyTap('f', [process.platform === 'darwin' ? 'command' : 'control']);
|
|
|
|
await asyncSleep(500);
|
2021-11-19 07:21:34 -08:00
|
|
|
const isFocused = await firstServer.$eval('#searchBox', (el) => el === document.activeElement);
|
|
|
|
isFocused.should.be.true;
|
|
|
|
const text = await firstServer.inputValue('#searchBox');
|
|
|
|
text.should.include('in:');
|
|
|
|
});
|
|
|
|
|
2022-02-02 13:02:45 -08:00
|
|
|
it.skip('MM-T816 Toggle Full Screen in the Menu Bar', async () => {
|
|
|
|
if (process.platform === 'win32' || process.platform === 'linux') {
|
|
|
|
const mainWindow = this.app.windows().find((window) => window.url().includes('index'));
|
|
|
|
const loadingScreen = this.app.windows().find((window) => window.url().includes('loadingScreen'));
|
|
|
|
await loadingScreen.waitForSelector('.LoadingScreen', {state: 'hidden'});
|
|
|
|
const firstServer = this.serverMap[`${config.teams[0].name}___TAB_MESSAGING`].win;
|
|
|
|
await env.loginToMattermost(firstServer);
|
|
|
|
await firstServer.waitForSelector('#searchBox');
|
|
|
|
let currentWidth = await firstServer.evaluate('window.outerWidth');
|
|
|
|
let currentHeight = await firstServer.evaluate('window.outerHeight');
|
|
|
|
await mainWindow.click('button.three-dot-menu');
|
|
|
|
robot.keyTap('v');
|
|
|
|
robot.keyTap('t');
|
|
|
|
robot.keyTap('enter');
|
|
|
|
await asyncSleep(1000);
|
|
|
|
const fullScreenWidth = await firstServer.evaluate('window.outerWidth');
|
|
|
|
const fullScreenHeight = await firstServer.evaluate('window.outerHeight');
|
|
|
|
fullScreenWidth.should.be.greaterThan(currentWidth);
|
|
|
|
fullScreenHeight.should.be.greaterThan(currentHeight);
|
|
|
|
await mainWindow.click('button.three-dot-menu');
|
|
|
|
robot.keyTap('v');
|
|
|
|
robot.keyTap('t');
|
|
|
|
robot.keyTap('enter');
|
|
|
|
await asyncSleep(1000);
|
|
|
|
currentWidth = await firstServer.evaluate('window.outerWidth');
|
|
|
|
currentHeight = await firstServer.evaluate('window.outerHeight');
|
|
|
|
currentWidth.should.be.lessThan(fullScreenWidth);
|
|
|
|
currentHeight.should.be.lessThan(fullScreenHeight);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-11-19 07:21:34 -08:00
|
|
|
describe('Reload', () => {
|
|
|
|
let browserWindow;
|
|
|
|
let webContentsId;
|
|
|
|
|
|
|
|
beforeEach(async () => {
|
|
|
|
const mainWindow = await this.app.firstWindow();
|
|
|
|
browserWindow = await this.app.browserWindow(mainWindow);
|
|
|
|
webContentsId = this.serverMap[`${config.teams[0].name}___TAB_MESSAGING`].webContentsId;
|
|
|
|
|
|
|
|
const loadingScreen = this.app.windows().find((window) => window.url().includes('loadingScreen'));
|
|
|
|
await loadingScreen.waitForSelector('.LoadingScreen', {state: 'hidden'});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('MM-T814 should reload page when pressing Ctrl+R', async () => {
|
|
|
|
const check = browserWindow.evaluate(setupPromise, webContentsId);
|
|
|
|
await asyncSleep(500);
|
|
|
|
robot.keyTap('r', ['control']);
|
|
|
|
const result = await check;
|
|
|
|
result.should.be.true;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('MM-T815 should reload page when pressing Ctrl+Shift+R', async () => {
|
|
|
|
const check = browserWindow.evaluate(setupPromise, webContentsId);
|
|
|
|
await asyncSleep(500);
|
|
|
|
robot.keyTap('r', ['control', 'shift']);
|
|
|
|
const result = await check;
|
|
|
|
result.should.be.true;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|