Add test to verify creation of new cloudron user
This commit is contained in:
parent
6da69be5f3
commit
cb5b4eff34
16
cloudron.js
16
cloudron.js
@ -174,3 +174,19 @@ Cloudron.prototype.update = function (toVersion) {
|
|||||||
console.log('Updated successfully'.green);
|
console.log('Updated successfully'.green);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Cloudron.prototype.addUser = function (username, email) {
|
||||||
|
var res = request.post(this._origin + '/api/v1/users').query({ access_token: this._credentials.accessToken }).send({ username: username, email: email }).end();
|
||||||
|
verifyResponse(res, 'Could not add user');
|
||||||
|
|
||||||
|
return res.body.userInfo;
|
||||||
|
};
|
||||||
|
|
||||||
|
Cloudron.prototype.resetPassword = function (resetToken, password) {
|
||||||
|
var res = request.get(this._origin + '/api/v1/session/password/setup.html').query({ reset_token: resetToken }).end();
|
||||||
|
verifyResponse(res, 'Could not get password setup site');
|
||||||
|
|
||||||
|
var csrf = res.text.match(/name="_csrf" value="(.*)"/)[1];
|
||||||
|
res = request.post(this._origin + '/api/v1/session/password/reset').type('form').send({ _csrf: csrf, resetToken: resetToken, password: password, passwordRepeat: password }).end();
|
||||||
|
verifyResponse(res, 'Could not setup password for user');
|
||||||
|
};
|
||||||
|
|
||||||
|
88
test/cloudron-user.js
Normal file
88
test/cloudron-user.js
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
#!/usr/bin/env node
|
||||||
|
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
var AppStore = require('../appstore.js'),
|
||||||
|
assert = require('assert'),
|
||||||
|
Cloudron = require('../cloudron.js'),
|
||||||
|
path = require('path'),
|
||||||
|
readlineSync = require('readline-sync'),
|
||||||
|
request = require('superagent-sync'),
|
||||||
|
semver = require('semver'),
|
||||||
|
util = require('util');
|
||||||
|
|
||||||
|
require('colors');
|
||||||
|
|
||||||
|
process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';
|
||||||
|
|
||||||
|
function verifyResponse(res, errorMessage) {
|
||||||
|
if (res.statusCode < 200 || res.statusCode > 299) {
|
||||||
|
console.log('Response error statusCode:%s error:%s body:%s', res.statusCode, res.error, res.body);
|
||||||
|
console.log(errorMessage.red);
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
describe('End to end testing', function () {
|
||||||
|
this.timeout(0);
|
||||||
|
|
||||||
|
var appStore = new AppStore('https://api.staging.cloudron.io');
|
||||||
|
|
||||||
|
var owner = {
|
||||||
|
username: 'test',
|
||||||
|
password: 'test1234',
|
||||||
|
email: 'test@cloudron.io'
|
||||||
|
};
|
||||||
|
|
||||||
|
var res, latestVersion, cloudron, appId, box, newUser;
|
||||||
|
|
||||||
|
it('can query versions', function () {
|
||||||
|
res = request.get('https://s3.amazonaws.com/staging-cloudron-releases/versions.json').end();
|
||||||
|
verifyResponse(res);
|
||||||
|
var boxVersions = Object.keys(res.body).sort(semver.rcompare);
|
||||||
|
latestVersion = boxVersions[0];
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can login to the store', function () {
|
||||||
|
var accessToken = appStore.getAccessToken(owner);
|
||||||
|
appStore.setCredentials(owner.password, accessToken);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can create a cloudron', function () {
|
||||||
|
box = appStore.createCloudron({
|
||||||
|
name: 'testbox-' + path.basename(__filename, '-test.js') + '.smartserver.io',
|
||||||
|
zoneName: 'smartserver.io',
|
||||||
|
region: 'sfo1',
|
||||||
|
size: '512mb',
|
||||||
|
version: latestVersion
|
||||||
|
});
|
||||||
|
cloudron = new Cloudron(box);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can activate the box', function () {
|
||||||
|
cloudron.activate(owner);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can login to the box', function () {
|
||||||
|
var token = cloudron.getOauthToken(owner);
|
||||||
|
cloudron.setCredentials(owner.password, token);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can create user', function () {
|
||||||
|
newUser = cloudron.addUser('newuser', 'test@cloudron.io');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can use reset token to reset password', function () {
|
||||||
|
cloudron.resetPassword(newUser.resetToken, 'newpassword');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can login as new user', function () {
|
||||||
|
cloudron.getOauthToken({ username: 'newuser', email: 'test@cloudron.io', password: 'newpassword' });
|
||||||
|
});
|
||||||
|
|
||||||
|
it('can delete the cloudron', function () {
|
||||||
|
// appStore.deleteCloudron(box);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
Loading…
Reference in New Issue
Block a user