cloudron-e2e-test/test/cloudron-user-test.js

71 lines
1.9 KiB
JavaScript
Raw Normal View History

#!/usr/bin/env node
'use strict';
/*
2015-06-22 06:57:13 +00:00
* This tests a flow for the cloudron 'user. The cloudron
* owner create a new user. This new user should be able to
* login with the resetToken.
*/
var AppStore = require('../appstore.js'),
Cloudron = require('../cloudron.js'),
common = require('../common.js');
require('colors');
process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';
var BOX_VERSION = process.env.BOX_VERSION;
2015-06-16 03:50:39 +00:00
describe('Cloudron user creation testing', function () {
this.timeout(0);
var appStore = new AppStore('https://api.staging.cloudron.io');
2015-07-23 20:46:47 +00:00
var owner = common.getOwner();
var cloudron, box, newUser;
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({
2015-06-19 20:06:00 +00:00
domain: common.cloudronDomain(__filename),
region: 'sfo1',
size: '512mb',
version: BOX_VERSION
});
2015-09-29 04:02:27 +00:00
box = appStore.waitForCloudron(box.id);
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 () {
2015-06-15 06:11:07 +00:00
newUser = cloudron.addUser('newuser', 'girish@forwardbias.in');
});
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 () {
2015-06-15 06:11:07 +00:00
appStore.deleteCloudron(box);
});
});