Rewrite tests with chai-as-promised
This commit is contained in:
@@ -31,6 +31,8 @@
|
||||
"babel-core": "^6.7.5",
|
||||
"babel-loader": "^6.2.4",
|
||||
"babel-preset-react": "^6.5.0",
|
||||
"chai": "^3.5.0",
|
||||
"chai-as-promised": "^5.3.0",
|
||||
"del": "^2.2.0",
|
||||
"electron-builder": "^3.11.0",
|
||||
"electron-connect": "^0.3.7",
|
||||
@@ -46,7 +48,6 @@
|
||||
"json-loader": "^0.5.4",
|
||||
"mocha": "^2.3.4",
|
||||
"mocha-circleci-reporter": "0.0.1",
|
||||
"should": "^8.0.1",
|
||||
"spectron": "~3.0.0",
|
||||
"style-loader": "^0.13.0",
|
||||
"through2": "^2.0.1",
|
||||
|
@@ -1,5 +1,12 @@
|
||||
'use strict';
|
||||
|
||||
const chai = require('chai');
|
||||
const chaiAsPromised = require('chai-as-promised');
|
||||
|
||||
chai.should();
|
||||
chai.use(chaiAsPromised);
|
||||
|
||||
|
||||
const path = require('path');
|
||||
const Application = require('spectron').Application;
|
||||
|
||||
@@ -21,10 +28,12 @@ module.exports = {
|
||||
configFilePath: config_file_path,
|
||||
mattermostURL: mattermost_url,
|
||||
getSpectronApp: function() {
|
||||
return new Application({
|
||||
const app = new Application({
|
||||
path: electron_binary_path,
|
||||
args: [`${path.join(source_root_dir, 'dist')}`, '--config-file=' + config_file_path]
|
||||
});
|
||||
chaiAsPromised.transferPromiseness = app.transferPromiseness
|
||||
return app;
|
||||
},
|
||||
shouldTestForPlatforms: function(testCase, platforms) {
|
||||
if (platforms.indexOf(process.platform) !== -1) {
|
||||
|
@@ -1,6 +1,5 @@
|
||||
'use strict';
|
||||
|
||||
const should = require('should');
|
||||
const path = require('path');
|
||||
const fs = require('fs');
|
||||
|
||||
@@ -9,10 +8,10 @@ const env = require('../modules/environment');
|
||||
describe('application', function() {
|
||||
this.timeout(10000);
|
||||
|
||||
before(function(done) {
|
||||
beforeEach(function(done) {
|
||||
this.app = env.getSpectronApp();
|
||||
fs.unlink(env.configFilePath, () => {
|
||||
done()
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
@@ -22,14 +21,19 @@ describe('application', function() {
|
||||
}
|
||||
});
|
||||
|
||||
it('should show a window', function() {
|
||||
return this.app.start().then(() => {
|
||||
return this.app.client.waitUntilWindowLoaded()
|
||||
.getWindowCount().should.eventually.equal(1)
|
||||
.browserWindow.isDevToolsOpened().should.eventually.be.false
|
||||
.browserWindow.isVisible().should.eventually.be.true
|
||||
});
|
||||
});
|
||||
|
||||
it('should show settings.html when there is no config file', function() {
|
||||
return this.app.start().then(() => {
|
||||
this.app.client
|
||||
.pause(1000)
|
||||
.getUrl().then(function(url) {
|
||||
var p = path.parse(url);
|
||||
p.base.should.equal('settings.html');
|
||||
})
|
||||
return this.app.client.waitUntilWindowLoaded()
|
||||
.getUrl().should.eventually.match(/\/settings.html$/)
|
||||
});
|
||||
});
|
||||
|
||||
@@ -38,12 +42,8 @@ describe('application', function() {
|
||||
url: env.mattermostURL
|
||||
}));
|
||||
return this.app.start().then(() => {
|
||||
this.app.client
|
||||
.pause(1000)
|
||||
.getUrl().then(function(url) {
|
||||
var p = path.parse(url);
|
||||
p.base.should.equal('index.html');
|
||||
});
|
||||
return this.app.client.waitUntilWindowLoaded()
|
||||
.getUrl().should.eventually.match(/\/index.html$/)
|
||||
});
|
||||
});
|
||||
|
||||
@@ -53,17 +53,12 @@ describe('application', function() {
|
||||
url: env.mattermostURL
|
||||
}));
|
||||
return this.app.start().then(() => {
|
||||
this.app.client
|
||||
.pause(1000)
|
||||
.getUrl().then(function(url) {
|
||||
var p = path.parse(url);
|
||||
p.base.should.equal('index.html');
|
||||
})
|
||||
.end().then(function() {
|
||||
var str = fs.readFileSync(env.configFilePath, 'utf8');
|
||||
var config = JSON.parse(str);
|
||||
config.version.should.equal(settings.version);
|
||||
});
|
||||
return this.app.client.waitUntilWindowLoaded()
|
||||
.getUrl().should.eventually.match(/\/index.html$/)
|
||||
}).then(function() {
|
||||
var str = fs.readFileSync(env.configFilePath, 'utf8');
|
||||
var config = JSON.parse(str);
|
||||
config.version.should.equal(settings.version);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
@@ -1,6 +1,5 @@
|
||||
'use strict';
|
||||
|
||||
const should = require('should');
|
||||
const path = require('path');
|
||||
const fs = require('fs');
|
||||
|
||||
@@ -20,15 +19,10 @@ describe('browser/index.html', function() {
|
||||
}]
|
||||
};
|
||||
|
||||
before(function(done) {
|
||||
this.app = env.getSpectronApp();
|
||||
fs.unlink(env.configFilePath, function(err) {
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
beforeEach(function() {
|
||||
fs.writeFileSync(env.configFilePath, JSON.stringify(config));
|
||||
this.app = env.getSpectronApp();
|
||||
return this.app.start();
|
||||
});
|
||||
|
||||
afterEach(function() {
|
||||
@@ -41,63 +35,33 @@ describe('browser/index.html', function() {
|
||||
fs.writeFileSync(env.configFilePath, JSON.stringify({
|
||||
url: env.mattermostURL
|
||||
}));
|
||||
return this.app.start().then(() => {
|
||||
this.app.client
|
||||
.init()
|
||||
.isExisting('#tabBar').then(function(isExisting) {
|
||||
isExisting.should.be.false();
|
||||
});
|
||||
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', function() {
|
||||
return this.app.start().then(() => {
|
||||
this.app.client
|
||||
.init()
|
||||
.getAttribute('#mattermostView0', 'src').then(function(attribute) {
|
||||
attribute.should.equal(config.teams[0].url);
|
||||
})
|
||||
.getAttribute('#mattermostView1', 'src').then(function(attribute) {
|
||||
attribute.should.equal(config.teams[1].url);
|
||||
})
|
||||
.isExisting('#mattermostView2').then(function(isExisting) {
|
||||
isExisting.should.be.false();
|
||||
});
|
||||
});
|
||||
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', function() {
|
||||
return this.app.start().then(() => {
|
||||
this.app.client
|
||||
.init()
|
||||
.getText('#teamTabItem0').then(function(text) {
|
||||
text.should.equal(config.teams[0].name);
|
||||
})
|
||||
.getText('#teamTabItem1').then(function(text) {
|
||||
text.should.equal(config.teams[1].name);
|
||||
})
|
||||
.isExisting('#teamTabItem2').then(function(isExisting) {
|
||||
isExisting.should.be.false();
|
||||
});
|
||||
});
|
||||
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', function() {
|
||||
return this.app.start().then(() => {
|
||||
this.app.client
|
||||
.init()
|
||||
.pause(1000)
|
||||
.waitForVisible('#mattermostView0', 1000)
|
||||
.isVisible('#mattermostView1').then(function(visility) {
|
||||
visility.should.be.false();
|
||||
})
|
||||
.click('#teamTabItem1')
|
||||
.pause(1000)
|
||||
.waitForVisible('#mattermostView1', 1000)
|
||||
.isVisible('#mattermostView0').then(function(visility) {
|
||||
visility.should.be.false();
|
||||
});
|
||||
});
|
||||
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', function() {
|
||||
@@ -109,9 +73,8 @@ describe('browser/index.html', function() {
|
||||
url: 'http://false'
|
||||
}]
|
||||
}));
|
||||
return this.app.start().then(() => {
|
||||
this.app.client
|
||||
.init()
|
||||
return this.app.restart().then(() => {
|
||||
return this.app.client.waitUntilWindowLoaded()
|
||||
.waitForVisible('#mattermostView0-fail', 20000)
|
||||
});
|
||||
});
|
||||
|
@@ -1,6 +1,5 @@
|
||||
'use strict';
|
||||
|
||||
const should = require('should');
|
||||
const path = require('path');
|
||||
const fs = require('fs');
|
||||
|
||||
@@ -8,8 +7,8 @@ const env = require('../../modules/environment');
|
||||
|
||||
function initClient(client) {
|
||||
return client
|
||||
.init()
|
||||
.url('file://' + path.join(env.sourceRootDir, 'dist/browser/settings.html'));
|
||||
.url('file://' + path.join(env.sourceRootDir, 'dist/browser/settings.html'))
|
||||
.waitUntilWindowLoaded();
|
||||
}
|
||||
|
||||
describe('browser/settings.html', function() {
|
||||
@@ -26,17 +25,10 @@ describe('browser/settings.html', function() {
|
||||
}]
|
||||
};
|
||||
|
||||
var chromedriver;
|
||||
var client;
|
||||
before(function(done) {
|
||||
this.app = env.getSpectronApp();
|
||||
fs.unlink(env.configFilePath, function(err) {
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
beforeEach(function() {
|
||||
fs.writeFileSync(env.configFilePath, JSON.stringify(config));
|
||||
this.app = env.getSpectronApp();
|
||||
return this.app.start();
|
||||
});
|
||||
|
||||
afterEach(function() {
|
||||
@@ -46,45 +38,25 @@ describe('browser/settings.html', function() {
|
||||
});
|
||||
|
||||
it('should show index.thml when Cancel button is clicked', function() {
|
||||
return this.app.start().then(() => {
|
||||
initClient(this.app.client)
|
||||
.waitForExist('#btnCancel')
|
||||
.click('#btnCancel')
|
||||
.pause(1000)
|
||||
.getUrl().then(function(url) {
|
||||
var url_split = url.split('/');
|
||||
url_split[url_split.length - 1].should.equal('index.html');
|
||||
});
|
||||
});
|
||||
return initClient(this.app.client)
|
||||
.click('#btnCancel')
|
||||
.pause(1000)
|
||||
.getUrl().should.eventually.match(/\/index.html$/)
|
||||
});
|
||||
|
||||
it('should show index.thml when Save button is clicked', function() {
|
||||
return this.app.start().then(() => {
|
||||
initClient(this.app.client)
|
||||
.waitForExist('#btnSave')
|
||||
.click('#btnSave')
|
||||
.pause(1000)
|
||||
.getUrl().then(function(url) {
|
||||
var url_split = url.split('/');
|
||||
url_split[url_split.length - 1].should.equal('index.html');
|
||||
});
|
||||
});
|
||||
return initClient(this.app.client)
|
||||
.click('#btnSave')
|
||||
.pause(1000)
|
||||
.getUrl().should.eventually.match(/\/index.html$/)
|
||||
});
|
||||
|
||||
describe('Options', function() {
|
||||
describe('Hide Menu Bar', function() {
|
||||
it('should appear on win32 or linux', function() {
|
||||
return this.app.start().then(() => {
|
||||
initClient(this.app.client)
|
||||
.isExisting('#inputHideMenuBar').then(function(isExisting) {
|
||||
if (process.platform === 'win32' || process.platform === 'linux') {
|
||||
isExisting.should.be.true();
|
||||
}
|
||||
else {
|
||||
isExisting.should.be.false();
|
||||
}
|
||||
});
|
||||
});
|
||||
const expected = (process.platform === 'win32' || process.platform === 'linux');
|
||||
return initClient(this.app.client)
|
||||
.isExisting('#inputHideMenuBar').should.eventually.equal(expected)
|
||||
});
|
||||
|
||||
[true, false].forEach(function(v) {
|
||||
@@ -94,28 +66,26 @@ describe('browser/settings.html', function() {
|
||||
Object.assign(new_config, config);
|
||||
new_config.hideMenuBar = v;
|
||||
fs.writeFileSync(env.configFilePath, JSON.stringify(new_config));
|
||||
return this.app.start().then(() => {
|
||||
initClient(this.app.client)
|
||||
.isSelected('#inputHideMenuBar input').then(function(value) {
|
||||
value.should.equal(v);
|
||||
this.app.browserWindow.isMenuBarAutoHide().should.equal(v);
|
||||
});
|
||||
return this.app.restart().then(() => {
|
||||
return initClient(this.app.client)
|
||||
.isSelected('#inputHideMenuBar input').should.eventually.equal(v)
|
||||
.browserWindow.isMenuBarAutoHide().should.eventually.equal(v);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
it('should be saved as config.json', function() {
|
||||
env.shouldTestForPlatforms(this, ['win32', 'linux']);
|
||||
return this.app.start().then(() => {
|
||||
initClient(this.app.client)
|
||||
.click('#inputHideMenuBar input')
|
||||
.click('#btnSave')
|
||||
.pause(1000)
|
||||
.then(function() {
|
||||
const saved_config = JSON.parse(fs.readFileSync(env.configFilePath, 'utf8'));
|
||||
saved_config.hideMenuBar.should.be.true();
|
||||
});
|
||||
});
|
||||
return this.app.restart().then(() => {
|
||||
return initClient(this.app.client)
|
||||
.click('#inputHideMenuBar input')
|
||||
.click('#btnSave')
|
||||
.pause(1000)
|
||||
})
|
||||
.then(() => {
|
||||
const saved_config = JSON.parse(fs.readFileSync(env.configFilePath, 'utf8'));
|
||||
saved_config.hideMenuBar.should.be.true;
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
@@ -1,4 +1,3 @@
|
||||
const should = require('should');
|
||||
const fs = require('fs');
|
||||
const settings = require('../../src/common/settings');
|
||||
|
||||
|
Reference in New Issue
Block a user