add tests
This commit is contained in:
parent
c32be4977e
commit
2397fd0d8b
4 changed files with 1725 additions and 1 deletions
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -1 +1,2 @@
|
||||||
scripts/node_modules
|
node_modules/
|
||||||
|
|
||||||
|
|
1585
test/package-lock.json
generated
Normal file
1585
test/package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load diff
24
test/package.json
Normal file
24
test/package.json
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
{
|
||||||
|
"name": "test",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"description": "",
|
||||||
|
"main": "test.js",
|
||||||
|
"scripts": {
|
||||||
|
"test": "echo \"Error: no test specified\" && exit 1"
|
||||||
|
},
|
||||||
|
"author": "",
|
||||||
|
"license": "ISC",
|
||||||
|
"devDependencies": {
|
||||||
|
"ejs": "^3.0.1",
|
||||||
|
"expect.js": "^0.3.1",
|
||||||
|
"mkdirp": "^1.0.3",
|
||||||
|
"mocha": "^7.1.0",
|
||||||
|
"rimraf": "^3.0.2",
|
||||||
|
"selenium-server-standalone-jar": "^3.141.59",
|
||||||
|
"selenium-webdriver": "^3.6.0",
|
||||||
|
"superagent": "^5.2.2"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"chromedriver": "^80.0.1"
|
||||||
|
}
|
||||||
|
}
|
114
test/test.js
Normal file
114
test/test.js
Normal file
|
@ -0,0 +1,114 @@
|
||||||
|
#!/usr/bin/env node
|
||||||
|
|
||||||
|
/* jslint node:true */
|
||||||
|
/* global it:false */
|
||||||
|
/* global xit:false */
|
||||||
|
/* global describe:false */
|
||||||
|
/* global before:false */
|
||||||
|
/* global after:false */
|
||||||
|
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
require('chromedriver');
|
||||||
|
|
||||||
|
var execSync = require('child_process').execSync,
|
||||||
|
expect = require('expect.js'),
|
||||||
|
path = require('path'),
|
||||||
|
webdriver = require('selenium-webdriver');
|
||||||
|
|
||||||
|
var by = require('selenium-webdriver').By,
|
||||||
|
until = require('selenium-webdriver').until,
|
||||||
|
Key = require('selenium-webdriver').Key,
|
||||||
|
Builder = require('selenium-webdriver').Builder;
|
||||||
|
|
||||||
|
if (!process.env.USERNAME || !process.env.PASSWORD || !process.env.EMAIL) {
|
||||||
|
console.log('USERNAME, PASSWORD and EMAIL env vars need to be set');
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
describe('Application life cycle test', function () {
|
||||||
|
this.timeout(0);
|
||||||
|
|
||||||
|
var server, browser = new Builder().forBrowser('chrome').build();
|
||||||
|
var username = process.env.USERNAME, password = process.env.PASSWORD;
|
||||||
|
var email = process.env.EMAIL;
|
||||||
|
|
||||||
|
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();
|
||||||
|
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
after(function (done) {
|
||||||
|
browser.quit();
|
||||||
|
server.stop();
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
var LOCATION = 'test';
|
||||||
|
var TEST_TIMEOUT = parseInt(process.env.TIMEOUT, 10) || 30000;
|
||||||
|
var app;
|
||||||
|
|
||||||
|
xit('build app', function () {
|
||||||
|
execSync('cloudron build', { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });
|
||||||
|
});
|
||||||
|
|
||||||
|
it('install app', function () {
|
||||||
|
execSync('cloudron install --location ' + LOCATION, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can get app information', function () {
|
||||||
|
var inspect = JSON.parse(execSync('cloudron inspect'));
|
||||||
|
|
||||||
|
app = inspect.apps.filter(function (a) { return a.location === LOCATION; })[0];
|
||||||
|
|
||||||
|
expect(app).to.be.an('object');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('backup app', function () {
|
||||||
|
execSync('cloudron backup create --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });
|
||||||
|
});
|
||||||
|
|
||||||
|
it('restore app', function () {
|
||||||
|
execSync('cloudron restore --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can restart app', function (done) {
|
||||||
|
execSync('cloudron restart --app ' + app.id);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('move to different location', function (done) {
|
||||||
|
execSync('cloudron configure --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');
|
||||||
|
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('uninstall app', function () {
|
||||||
|
execSync('cloudron uninstall --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });
|
||||||
|
});
|
||||||
|
|
||||||
|
// test update
|
||||||
|
it('can install from appstore', function () {
|
||||||
|
execSync(`cloudron install --appstore-id ${app.manifest.id} --location ${LOCATION}`, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });
|
||||||
|
var inspect = JSON.parse(execSync('cloudron inspect'));
|
||||||
|
app = inspect.apps.filter(function (a) { return a.location === LOCATION; })[0];
|
||||||
|
expect(app).to.be.an('object');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can update', function () {
|
||||||
|
execSync('cloudron update --app ' + LOCATION, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });
|
||||||
|
let inspect = JSON.parse(execSync('cloudron inspect'));
|
||||||
|
app = inspect.apps.filter(function (a) { return a.location === LOCATION; })[0];
|
||||||
|
});
|
||||||
|
|
||||||
|
it('uninstall app', function () {
|
||||||
|
execSync('cloudron uninstall --app ' + app.id, { cwd: path.resolve(__dirname, '..'), stdio: 'inherit' });
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue