X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=test%2Ftest.js;h=979ffdeaf3fbf81f240fb9f0a2defc927a055153;hb=efdc0490694375fece7804c70877fb238a91a8eb;hp=7e1e8565386dcd9d019936005f6615c18014282e;hpb=8c87c0db33704755c3ff9a48fd0089d6ae72928d;p=perso%2FImmae%2FProjets%2FNodejs%2FSurfer.git diff --git a/test/test.js b/test/test.js index 7e1e856..979ffde 100644 --- a/test/test.js +++ b/test/test.js @@ -2,65 +2,71 @@ 'use strict'; +/* global describe */ +/* global before */ +/* global after */ +/* global it */ + var execSync = require('child_process').execSync, expect = require('expect.js'), path = require('path'), - fs = require('fs'), + util = require('util'), superagent = require('superagent'), webdriver = require('selenium-webdriver'); var by = webdriver.By, - Keys = webdriver.Key, until = webdriver.until; -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); } +const EXEC_OPTIONS = { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' }; + describe('Application life cycle test', function () { this.timeout(0); - var chrome = require('selenium-webdriver/chrome'); - var server, browser = new chrome.Driver(); + var browser; before(function (done) { - var seleniumJar= require('selenium-server-standalone-jar'); - var SeleniumServer = require('selenium-webdriver/remote').SeleniumServer; - server = new SeleniumServer(seleniumJar.path, { port: 4444 }); - server.start(); + browser = new webdriver.Builder() + .forBrowser('chrome') + // .setChromeOptions(new chrome.Options().addArguments(['no-sandbox', 'headless'])) + .build(); done(); }); after(function (done) { browser.quit(); - server.stop(); done(); }); - var LOCATION = 'surfer'; + var LOCATION = 'test'; var TEST_TIMEOUT = 10000; var TEST_FILE_NAME_0 = 'index.html'; var TEST_FILE_NAME_1 = 'test.txt'; var app; + function waitForElement(elem) { + return browser.wait(until.elementLocated(elem), TEST_TIMEOUT).then(function () { + return browser.wait(until.elementIsVisible(browser.findElement(elem)), TEST_TIMEOUT); + }); + } + // tests which are used more than once function login(done) { browser.manage().deleteAllCookies(); browser.get('https://' + app.fqdn + '/_admin'); - browser.wait(until.elementLocated(by.id('inputUsername')), TEST_TIMEOUT).then(function () { - browser.wait(until.elementIsVisible(browser.findElement(by.id('inputUsername'))), TEST_TIMEOUT).then(function () { - browser.findElement(by.id('inputUsername')).sendKeys(process.env.USERNAME); - browser.findElement(by.id('inputPassword')).sendKeys(process.env.PASSWORD); - browser.findElement(by.id('loginForm')).submit(); + waitForElement(by.id('loginUsernameInput')).then(function () { + browser.findElement(by.id('loginUsernameInput')).sendKeys(process.env.USERNAME); + browser.findElement(by.id('loginPasswordInput')).sendKeys(process.env.PASSWORD); + browser.findElement(by.id('loginSubmitButton')).click(); - browser.wait(until.elementIsVisible(browser.findElement(by.id('logoutButton'))), TEST_TIMEOUT).then(function () { - done(); - }); + waitForElement(by.id('burgerMenuButton')).then(function () { + done(); }); }); } @@ -68,11 +74,16 @@ describe('Application life cycle test', function () { function logout(done) { browser.get('https://' + app.fqdn + '/_admin'); - browser.wait(until.elementLocated(by.id('logoutButton')), TEST_TIMEOUT).then(function () { - browser.wait(until.elementIsVisible(browser.findElement(by.id('logoutButton'))), TEST_TIMEOUT).then(function () { + waitForElement(by.id('burgerMenuButton')).then(function () { + browser.findElement(by.id('burgerMenuButton')).click(); + + // wait for open animation + browser.sleep(5000); + + waitForElement(by.id('logoutButton')).then(function () { browser.findElement(by.id('logoutButton')).click(); - browser.wait(until.elementIsVisible(browser.findElement(by.id('inputPassword'))), TEST_TIMEOUT).then(function () { + waitForElement(by.id('loginUsernameInput')).then(function () { done(); }); }); @@ -82,7 +93,7 @@ describe('Application life cycle test', function () { function checkFileIsListed(name, done) { browser.get('https://' + app.fqdn + '/_admin'); - browser.wait(until.elementLocated(by.xpath('//*[text()="' + name + '"]')), TEST_TIMEOUT).then(function () { + waitForElement(by.xpath('//*[text()="' + name + '"]')).then(function () { done(); }); } @@ -90,7 +101,7 @@ describe('Application life cycle test', function () { function checkFileIsPresent(done) { browser.get('https://' + app.fqdn + '/' + TEST_FILE_NAME_0); - browser.wait(until.elementLocated(by.xpath('//*[text()="test"]')), TEST_TIMEOUT).then(function () { + waitForElement(by.xpath('//*[text()="test"]')).then(function () { done(); }); } @@ -98,7 +109,7 @@ describe('Application life cycle test', function () { function checkIndexFileIsServedUp(done) { browser.get('https://' + app.fqdn); - browser.wait(until.elementLocated(by.xpath('//*[text()="test"]')), TEST_TIMEOUT).then(function () { + waitForElement(by.xpath('//*[text()="test"]')).then(function () { done(); }); } @@ -106,25 +117,30 @@ describe('Application life cycle test', function () { function checkFileIsGone(name, done) { superagent.get('https://' + app.fqdn + '/' + name).end(function (error, result) { expect(error).to.be.an('object'); - expect(result.statusCode).to.equal(404); + expect(error.response.status).to.equal(404); + expect(result).to.be.an('object'); done(); }); } + function cliLogin(done) { + execSync(util.format('%s login %s --username %s --password %s', path.join(__dirname, '/../cli/surfer.js'), app.fqdn, process.env.USERNAME, process.env.PASSWORD), { stdio: 'inherit' } ); + done(); + } + function uploadFile(name, done) { // File upload can't be tested with selenium, since the file input is not visible and thus can't be interacted with :-( - fs.writeFileSync(process.env.HOME + '/.surfer.json', JSON.stringify({ server: 'https://' + app.fqdn, username: process.env.USERNAME, password: process.env.PASSWORD })); - execSync(path.join(__dirname, '/../cli/surfer.js') + ' put ' + path.join(__dirname, name), { stdio: 'inherit' } ); + execSync(path.join(__dirname, '/../cli/surfer.js') + ' put ' + path.join(__dirname, name) + ' /', { stdio: 'inherit' } ); done(); } xit('build app', function () { - execSync('cloudron build', { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' }); + execSync('cloudron build', EXEC_OPTIONS); }); it('install app', function () { - execSync('cloudron install --new --wait --location ' + LOCATION, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' }); + execSync('cloudron install --new --wait --location ' + LOCATION, EXEC_OPTIONS); }); it('can get app information', function () { @@ -136,6 +152,7 @@ describe('Application life cycle test', function () { }); it('can login', login); + it('can cli login', cliLogin); it('can upload file', uploadFile.bind(null, TEST_FILE_NAME_0)); it('file is listed', checkFileIsListed.bind(null, TEST_FILE_NAME_0)); it('file is served up', checkFileIsPresent); @@ -143,7 +160,6 @@ describe('Application life cycle test', function () { it('can upload second file', uploadFile.bind(null, TEST_FILE_NAME_1)); it('file is listed', checkFileIsListed.bind(null, TEST_FILE_NAME_1)); it('can delete second file with cli', function (done) { - fs.writeFileSync(process.env.HOME + '/.surfer.json', JSON.stringify({ server: 'https://' + app.fqdn, username: process.env.USERNAME, password: process.env.PASSWORD })); execSync(path.join(__dirname, '/../cli/surfer.js') + ' del ' + TEST_FILE_NAME_1, { stdio: 'inherit' } ); done(); }); @@ -151,11 +167,11 @@ describe('Application life cycle test', function () { it('can logout', logout); it('backup app', function () { - execSync('cloudron backup create --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' }); + execSync('cloudron backup create --app ' + app.id, EXEC_OPTIONS); }); it('restore app', function () { - execSync('cloudron restore --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' }); + execSync('cloudron restore --app ' + app.id, EXEC_OPTIONS); }); it('can login', login); @@ -165,12 +181,17 @@ describe('Application life cycle test', function () { it('second file is still gone', checkFileIsGone.bind(null, TEST_FILE_NAME_1)); it('can logout', logout); - it('move to different location', function () { + it('move to different location', function (done) { browser.manage().deleteAllCookies(); - execSync('cloudron install --location ' + LOCATION + '2 --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' }); - var inspect = JSON.parse(execSync('cloudron inspect')); - app = inspect.apps.filter(function (a) { return a.location === LOCATION + '2'; })[0]; - expect(app).to.be.an('object'); + + // ensure we don't hit NXDOMAIN in the mean time + browser.get('about:blank').then(function () { + execSync('cloudron configure --location ' + LOCATION + '2 --app ' + app.id, EXEC_OPTIONS); + var inspect = JSON.parse(execSync('cloudron inspect')); + app = inspect.apps.filter(function (a) { return a.location === LOCATION + '2'; })[0]; + expect(app).to.be.an('object'); + done(); + }); }); it('can login', login); @@ -179,7 +200,11 @@ describe('Application life cycle test', function () { it('file is served up', checkIndexFileIsServedUp); it('can logout', logout); - it('uninstall app', function () { - execSync('cloudron uninstall --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' }); + it('uninstall app', function (done) { + // ensure we don't hit NXDOMAIN in the mean time + browser.get('about:blank').then(function () { + execSync('cloudron uninstall --app ' + app.id, EXEC_OPTIONS); + done(); + }); }); });