Added tests

This commit is contained in:
Dennis Schwerdel 2017-05-08 11:47:39 +02:00
parent b700f42b17
commit f51c71c9ef
4 changed files with 57 additions and 72 deletions

View File

@ -15,7 +15,7 @@
"tcpPorts": { "tcpPorts": {
"PORT": { "PORT": {
"title": "Port", "title": "Port",
"description": "Port over which syncthing will exchange data", "description": "Port over which syncthing will exchange data (do not disable)",
"defaultValue": 22000, "defaultValue": 22000,
"containerPort": 22000 "containerPort": 22000
} }

View File

@ -32,6 +32,6 @@ cd syncthing-app/test
npm install npm install
export PATH=$PATH:node_modules/.bin export PATH=$PATH:node_modules/.bin
mocha --bail test.js USERNAME=user PASSWORD=password mocha --bail test.js
``` ```

View File

@ -8,6 +8,7 @@ daemon off;
# Send logs to stderr # Send logs to stderr
error_log /dev/stderr warn; error_log /dev/stderr warn;
events { events {
worker_connections 768; worker_connections 768;
} }
@ -24,20 +25,23 @@ http {
fastcgi_temp_path /tmp/fastcgi_temp 1 2; fastcgi_temp_path /tmp/fastcgi_temp 1 2;
uwsgi_temp_path /tmp/uwsgi_temp 1 2; uwsgi_temp_path /tmp/uwsgi_temp 1 2;
scgi_temp_path /tmp/scgi_temp 1 2; scgi_temp_path /tmp/scgi_temp 1 2;
proxy_buffering off;
proxy_cache_path /tmp/proxy_cache levels=1:2 keys_zone=my_cache:10m max_size=100m inactive=60m use_temp_path=off;
proxy_cache my_cache;
server { server {
error_log /dev/stderr warn; error_log /dev/stderr warn;
listen 8000 default_server; listen 8000 default_server;
server_name _; server_name _;
proxy_set_header Authorization "Basic YWRtaW46YWRtaW4=";
proxy_read_timeout 120s;
location /check { location /check {
proxy_pass http://localhost:3000/syncthing/app.js; proxy_pass http://localhost:3000/syncthing/app.js;
proxy_set_header Authorization "Basic YWRtaW46YWRtaW4=";
} }
location / { location / {
auth_ldap "Forbidden"; auth_ldap "Forbidden";
auth_ldap_servers cloudron; auth_ldap_servers cloudron;
proxy_pass http://localhost:3000; proxy_pass http://localhost:3000;
proxy_set_header Authorization "Basic YWRtaW46YWRtaW4=";
} }
} }
} }

View File

@ -19,12 +19,17 @@ var bucket_prefix = 'bucket',
process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0'; process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';
if (!process.env.USERNAME || !process.env.PASSWORD) {
console.log('USERNAME and PASSWORD env vars need to be set');
process.exit(1);
}
describe('Application life cycle test', function () { describe('Application life cycle test', function () {
this.timeout(0); this.timeout(0);
var chrome = require('selenium-webdriver/chrome'); var chrome = require('selenium-webdriver/chrome');
var server, browser = new chrome.Driver(); var server, browser = new chrome.Driver();
var username = process.env.USERNAME, password = process.env.PASSWORD;
before(function (done) { before(function (done) {
var seleniumJar= require('selenium-server-standalone-jar'); var seleniumJar= require('selenium-server-standalone-jar');
@ -41,14 +46,13 @@ describe('Application life cycle test', function () {
done(); done();
}); });
var LOCATION = 'minio-test'; var LOCATION = 'syncthing-test';
var TEST_TIMEOUT = 10000; var TEST_TIMEOUT = 30000;
var SYNC_PORT = 22001;
var app; var app;
function pageLoaded(callback) { function pageLoaded(callback) {
return browser.wait(until.elementLocated(by.className('page-load pl-0 pl-1')), TEST_TIMEOUT).then(function () { browser.wait(until.titleMatches(/[0-9a-f]{12} \| Syncthing/), TEST_TIMEOUT).then(callback);
callback();
});
} }
function visible(selector, callback) { function visible(selector, callback) {
@ -59,67 +63,47 @@ describe('Application life cycle test', function () {
}); });
} }
function login(callback) { function loadPage(callback) {
browser.manage().deleteAllCookies(); browser.manage().deleteAllCookies();
browser.get('https://' + app.fqdn); browser.get('https://' + username + ':' + password + '@' + app.fqdn);
pageLoaded(function() {
visible(by.id('accessKey'), function () { callback();
browser.findElement(by.id('accessKey')).sendKeys(accessKey);
browser.findElement(by.id('secretKey')).sendKeys(secretKey);
browser.findElement(by.className('lw-btn')).click();
browser.wait(until.elementLocated(by.id('top-right-menu')), TEST_TIMEOUT).then(function () { callback(); });
}); });
} }
function logout(callback) { function addFolder(callback) {
browser.get('https://' + app.fqdn); pageLoaded(function() {
browser.findElement(by.css('[ng-click*=addFolder]')).click();
pageLoaded(function () { visible(by.id('folderPath'), function() {
visible(by.id('top-right-menu'), function () { browser.findElement(by.id('folderLabel')).sendKeys('test').then(function() {
browser.findElement(by.id('top-right-menu')).click(); browser.findElement(by.id('folderPath')).sendKeys('/app/data/test').then(function() {
visible(by.xpath('//*[text()="Sign Out "]'), function () { //Clear and re-enter the folder to avoid race with auto-completion
browser.findElement(by.xpath('//*[text()="Sign Out "]')).click(); browser.findElement(by.id('folderPath')).clear().then(function() {
browser.findElement(by.id('folderPath')).sendKeys('/app/data/test').then(function() {
browser.wait(until.elementLocated(by.id('accessKey')), TEST_TIMEOUT).then(function () { callback(); }); browser.findElement(by.css('[ng-click*=saveFolder]')).click().then(function() {
}); browser.wait(until.elementLocated(by.css('#folders .panel-status span[ng-switch-when=unshared]')), TEST_TIMEOUT).then(function() {
});
});
}
function addBucket(callback) {
bucket_id = bucket_id + 1;
bucket = bucket_prefix + bucket_id;
browser.get('https://' + app.fqdn);
pageLoaded(function () {
visible(by.className('fa fa-plus'), function () {
browser.findElement(by.className('fa fa-plus')).click();
visible(by.className('fa fa-hdd-o'), function () {
browser.findElement(by.className('fa fa-hdd-o')).click();
visible(by.xpath('//*[@class="modal-body"]/form/div/input'), function() {
browser.findElement(by.xpath('//*[@class="modal-body"]/form/div/input')).sendKeys(bucket);
browser.findElement(by.xpath('//*[@class="modal-body"]/form')).submit();
visible(by.xpath('//*[@class="main"]/a[text()="' + bucket + '"]'), function() {
callback(); callback();
}); });
}); });
}); });
}); });
}); });
});
});
});
} }
function openSettings(callback) { function removeFolder(callback) {
browser.get('https://' + app.fqdn); pageLoaded(function() {
browser.findElement(by.css('#folders button')).click();
pageLoaded(function () { setTimeout(function() {
visible(by.id('top-right-menu'), function () { browser.findElement(by.css('#folder-0 button[ng-click*=editFolder]')).click();
browser.findElement(by.id('top-right-menu')).click(); setTimeout(function() {
visible(by.xpath('//*[text()="Settings "]'), function () { browser.findElement(by.css('[ng-click*=deleteFolder]')).click().then(function() {
browser.findElement(by.xpath('//*[text()="Settings "]')).click(); setTimeout(callback, 500); //This needs to run for some time
browser.wait(until.elementLocated(by.xpath('//*[text()="Generate"]')), TEST_TIMEOUT).then(function () { callback(); });
});
}); });
}, 500); //No way to check for visibility of angular-js components
}, 500); //No way to check for visibility of angular-js components
}); });
} }
@ -128,7 +112,7 @@ describe('Application life cycle test', function () {
}); });
it('install app', function () { it('install app', function () {
execSync('cloudron install --new --wait --location ' + LOCATION, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' }); execSync('cloudron install --new --wait --port-bindings PORT=' + SYNC_PORT + ' --location ' + LOCATION, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });
}); });
it('can get app information', function () { it('can get app information', function () {
@ -139,10 +123,9 @@ describe('Application life cycle test', function () {
expect(app).to.be.an('object'); expect(app).to.be.an('object');
}); });
it('can login', login); it('can load page', loadPage);
it('can add buckets', addBucket); it('can add folder', addFolder);
it('can open settings', openSettings); it('can remove folder', removeFolder);
it('can logout', logout);
it('backup app', function () { it('backup app', function () {
execSync('cloudron backup create --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' }); execSync('cloudron backup create --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });
@ -152,10 +135,9 @@ describe('Application life cycle test', function () {
execSync('cloudron restore --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' }); execSync('cloudron restore --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });
}); });
it('can login', login); it('can load page', loadPage);
it('can add buckets', addBucket); it('can add folder', addFolder);
it('can open settings', openSettings); it('can remove folder', removeFolder);
it('can logout', logout);
it('move to different location', function () { it('move to different location', function () {
browser.manage().deleteAllCookies(); browser.manage().deleteAllCookies();
@ -165,10 +147,9 @@ describe('Application life cycle test', function () {
expect(app).to.be.an('object'); expect(app).to.be.an('object');
}); });
it('can login', login); it('can load page', loadPage);
it('can add buckets', addBucket); it('can add folder', addFolder);
it('can open settings', openSettings); it('can remove folder', removeFolder);
it('can logout', logout);
it('uninstall app', function () { it('uninstall app', function () {
execSync('cloudron uninstall --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' }); execSync('cloudron uninstall --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });