Wait for dns to propagate on restore
This commit is contained in:
parent
d5f77ca116
commit
b19d5a1d66
@ -47,10 +47,11 @@ AppStore.prototype.waitForCloudron = function (boxId) {
|
|||||||
var creationTime = new Date();
|
var creationTime = new Date();
|
||||||
process.stdout.write('Waiting for cloudron to come up.');
|
process.stdout.write('Waiting for cloudron to come up.');
|
||||||
|
|
||||||
|
var res;
|
||||||
while (true) {
|
while (true) {
|
||||||
sleep(10);
|
sleep(10);
|
||||||
process.stdout.write('.');
|
process.stdout.write('.');
|
||||||
var res = request.get(this._origin + '/api/v1/cloudrons/' + boxId).query({ accessToken: this._credentials.accessToken }).end();
|
res = request.get(this._origin + '/api/v1/cloudrons/' + boxId).query({ accessToken: this._credentials.accessToken }).end();
|
||||||
verifyResponse(res, 'Could not query cloudron status');
|
verifyResponse(res, 'Could not query cloudron status');
|
||||||
|
|
||||||
if (res.body.box.status === 'ready') {
|
if (res.body.box.status === 'ready') {
|
||||||
@ -59,7 +60,9 @@ AppStore.prototype.waitForCloudron = function (boxId) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
debug('Box created in %s minutes'.green, (new Date() - creationTime) / 60000);
|
debug('Box created in %s minutes with IP:%s'.green, (new Date() - creationTime) / 60000, res.body.box.ip);
|
||||||
|
|
||||||
|
return res.body.box;
|
||||||
};
|
};
|
||||||
|
|
||||||
AppStore.prototype.createCloudron = function (box) {
|
AppStore.prototype.createCloudron = function (box) {
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
"async": "^1.4.0",
|
"async": "^1.4.0",
|
||||||
"colors": "^1.1.0",
|
"colors": "^1.1.0",
|
||||||
"debug": "^2.2.0",
|
"debug": "^2.2.0",
|
||||||
|
"dns-sync": "^0.1.3",
|
||||||
"mocha": "^2.2.5",
|
"mocha": "^2.2.5",
|
||||||
"once": "^1.3.2",
|
"once": "^1.3.2",
|
||||||
"parallel-mocha": "0.0.7",
|
"parallel-mocha": "0.0.7",
|
||||||
|
@ -11,6 +11,7 @@ var AppStore = require('../appstore.js'),
|
|||||||
assert = require('assert'),
|
assert = require('assert'),
|
||||||
Cloudron = require('../cloudron.js'),
|
Cloudron = require('../cloudron.js'),
|
||||||
common = require('../common.js'),
|
common = require('../common.js'),
|
||||||
|
dnsSync = require('dns-sync'),
|
||||||
request = require('superagent-sync'),
|
request = require('superagent-sync'),
|
||||||
semver = require('semver'),
|
semver = require('semver'),
|
||||||
sleep = require('sleep').sleep;
|
sleep = require('sleep').sleep;
|
||||||
@ -89,13 +90,22 @@ describe('Cloudron backup testing', function () {
|
|||||||
assert.strictEqual(backupInfo.dependsOn.length, 1);
|
assert.strictEqual(backupInfo.dependsOn.length, 1);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
var cloudronIp;
|
||||||
|
|
||||||
it('can restore the box', function () {
|
it('can restore the box', function () {
|
||||||
appStore.restore(box.id, backupInfo.restoreKey);
|
appStore.restore(box.id, backupInfo.restoreKey);
|
||||||
appStore.waitForCloudron(box.id);
|
cloudronIp = appStore.waitForCloudron(box.id);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('wait for cloudron to be networked', function () {
|
it('wait for local dns', function () {
|
||||||
sleep(30); // DO networking
|
for (var i = 0; i < 20; i++) {
|
||||||
|
var ip = dnsSync.resolve(box.domain);
|
||||||
|
console.dir(ip);
|
||||||
|
if (ip === cloudronIp) return;
|
||||||
|
|
||||||
|
debug('waiting for local dns to change from %s to %s', ips[0], cloudronIp);
|
||||||
|
sleep(30);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
it('can login to cloudron', function () {
|
it('can login to cloudron', function () {
|
||||||
|
Loading…
Reference in New Issue
Block a user