182 lines
5.4 KiB
JavaScript
182 lines
5.4 KiB
JavaScript
'use strict';
|
|
|
|
const fs = require('fs');
|
|
const http = require('http');
|
|
const path = require('path');
|
|
|
|
const env = require('../../modules/environment');
|
|
|
|
describe('browser/index.html', function desc() {
|
|
this.timeout(10000);
|
|
|
|
const config = {
|
|
version: 1,
|
|
teams: [{
|
|
name: 'example_1',
|
|
url: env.mattermostURL + '1'
|
|
}, {
|
|
name: 'example_2',
|
|
url: env.mattermostURL + '2'
|
|
}]
|
|
};
|
|
|
|
const serverPort = 8181;
|
|
|
|
before(() => {
|
|
function serverCallback(req, res) {
|
|
res.writeHead(200, {
|
|
'Content-Type': 'text/html'
|
|
});
|
|
res.end(fs.readFileSync(path.resolve(env.sourceRootDir, 'test/modules/test.html'), 'utf-8'));
|
|
}
|
|
this.server = http.createServer(serverCallback).listen(serverPort, '127.0.0.1');
|
|
});
|
|
|
|
beforeEach(() => {
|
|
fs.writeFileSync(env.configFilePath, JSON.stringify(config));
|
|
this.app = env.getSpectronApp();
|
|
return this.app.start();
|
|
});
|
|
|
|
afterEach(() => {
|
|
if (this.app && this.app.isRunning()) {
|
|
return this.app.stop();
|
|
}
|
|
return true;
|
|
});
|
|
|
|
after((done) => {
|
|
this.server.close(done);
|
|
});
|
|
|
|
it('should NOT show tabs when there is one team', () => {
|
|
fs.writeFileSync(env.configFilePath, JSON.stringify({
|
|
url: env.mattermostURL
|
|
}));
|
|
return this.app.restart().then(() => {
|
|
return this.app.client.waitUntilWindowLoaded().
|
|
isExisting('#tabBar').should.eventually.be.false;
|
|
});
|
|
});
|
|
|
|
it('should set src of webview from config file', () => {
|
|
return this.app.client.waitUntilWindowLoaded().
|
|
getAttribute('#mattermostView0', 'src').should.eventually.equal(config.teams[0].url).
|
|
getAttribute('#mattermostView1', 'src').should.eventually.equal(config.teams[1].url).
|
|
isExisting('#mattermostView2').should.eventually.be.false;
|
|
});
|
|
|
|
it('should set name of tab from config file', () => {
|
|
return this.app.client.waitUntilWindowLoaded().
|
|
getText('#teamTabItem0').should.eventually.equal(config.teams[0].name).
|
|
getText('#teamTabItem1').should.eventually.equal(config.teams[1].name);
|
|
});
|
|
|
|
it('should show only the selected team', () => {
|
|
return this.app.client.waitUntilWindowLoaded().
|
|
isVisible('#mattermostView0').should.eventually.be.true.
|
|
isVisible('#mattermostView1').should.eventually.be.false.
|
|
click('#teamTabItem1').
|
|
pause(1000).
|
|
isVisible('#mattermostView1').should.eventually.be.true.
|
|
isVisible('#mattermostView0').should.eventually.be.false;
|
|
});
|
|
|
|
it('should show error when using incorrect URL', () => {
|
|
this.timeout(30000);
|
|
fs.writeFileSync(env.configFilePath, JSON.stringify({
|
|
version: 1,
|
|
teams: [{
|
|
name: 'error_1',
|
|
url: 'http://false'
|
|
}]
|
|
}));
|
|
return this.app.restart().then(() => {
|
|
return this.app.client.waitUntilWindowLoaded().
|
|
waitForVisible('#mattermostView0-fail', 20000);
|
|
});
|
|
});
|
|
|
|
it('should set window title by using webview\'s one', () => {
|
|
fs.writeFileSync(env.configFilePath, JSON.stringify({
|
|
version: 1,
|
|
teams: [{
|
|
name: 'title_test',
|
|
url: `http://localhost:${serverPort}`
|
|
}]
|
|
}));
|
|
return this.app.restart().then(() => {
|
|
return this.app.client.waitUntilWindowLoaded().pause(1000);
|
|
}).then(() => {
|
|
return this.app.browserWindow.getTitle().should.eventually.equal('Mattermost Desktop testing html');
|
|
});
|
|
});
|
|
|
|
it('should update window title when the activated tab\'s title is updated', () => {
|
|
fs.writeFileSync(env.configFilePath, JSON.stringify({
|
|
version: 1,
|
|
teams: [{
|
|
name: 'title_test_0',
|
|
url: `http://localhost:${serverPort}`
|
|
}, {
|
|
name: 'title_test_1',
|
|
url: `http://localhost:${serverPort}`
|
|
}]
|
|
}));
|
|
return this.app.restart().then(() => {
|
|
return this.app.client.waitUntilWindowLoaded().pause(500);
|
|
}).then(() => {
|
|
return this.app.client.
|
|
windowByIndex(1).
|
|
execute(() => {
|
|
document.title = 'Title 0';
|
|
}).
|
|
windowByIndex(0).
|
|
browserWindow.getTitle().should.eventually.equal('Title 0').
|
|
windowByIndex(2).
|
|
execute(() => {
|
|
document.title = 'Title 1';
|
|
}).
|
|
windowByIndex(0).
|
|
browserWindow.getTitle().should.eventually.equal('Title 0');
|
|
});
|
|
});
|
|
|
|
it('should update window title when a tab is selected', () => {
|
|
fs.writeFileSync(env.configFilePath, JSON.stringify({
|
|
version: 1,
|
|
teams: [{
|
|
name: 'title_test_0',
|
|
url: `http://localhost:${serverPort}`
|
|
}, {
|
|
name: 'title_test_1',
|
|
url: `http://localhost:${serverPort}`
|
|
}]
|
|
}));
|
|
return this.app.restart().then(() => {
|
|
return this.app.client.
|
|
waitUntilWindowLoaded().
|
|
pause(500).
|
|
windowByIndex(1).
|
|
execute(() => {
|
|
document.title = 'Title 0';
|
|
}).
|
|
windowByIndex(2).
|
|
execute(() => {
|
|
document.title = 'Title 1';
|
|
}).
|
|
windowByIndex(0).
|
|
browserWindow.getTitle().should.eventually.equal('Title 0').
|
|
click('#teamTabItem1').
|
|
browserWindow.getTitle().should.eventually.equal('Title 1');
|
|
});
|
|
});
|
|
|
|
it('should open the new server prompt after clicking the add button', () => {
|
|
// See settings_test for specs that cover the actual prompt
|
|
return this.app.client.waitUntilWindowLoaded().
|
|
click('#tabBarAddNewTeam').
|
|
isExisting('#newServerModal').should.eventually.be.true;
|
|
});
|
|
});
|