rmcouchdb doesn't drop everything if dbname is absent; mkcouchdb reports helpful error message if dbname is absent
This commit is contained in:
parent
0b295a3e15
commit
b628dbe1d9
|
@ -68,8 +68,7 @@ possible to write in your configuration file:
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
Note, however, that if you call 'rmcouchdb' without a sub-argument, in
|
Note that if you call `rmcouchdb` without a sub-argument, it will not delete any databases.
|
||||||
keeping with grunt's standards, it will drop *all* of your databases!
|
|
||||||
|
|
||||||
## Demo
|
## Demo
|
||||||
|
|
||||||
|
|
|
@ -34,6 +34,7 @@ module.exports = function(grunt) {
|
||||||
dbname = parts.pathname.replace(/^\//, '');
|
dbname = parts.pathname.replace(/^\//, '');
|
||||||
try {
|
try {
|
||||||
nano = require('nano')(parts.protocol + '//' + parts.host);
|
nano = require('nano')(parts.protocol + '//' + parts.host);
|
||||||
|
if (dbname) {
|
||||||
nano.db.destroy(dbname, function(err) {
|
nano.db.destroy(dbname, function(err) {
|
||||||
if (err) {
|
if (err) {
|
||||||
if (err.status_code && err.status_code === 404) {
|
if (err.status_code && err.status_code === 404) {
|
||||||
|
@ -49,6 +50,10 @@ module.exports = function(grunt) {
|
||||||
}
|
}
|
||||||
return done(err, null);
|
return done(err, null);
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
grunt.log.writeln("No database specified... skipping.");
|
||||||
|
return done(null, null);
|
||||||
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
grunt.warn(e);
|
grunt.warn(e);
|
||||||
done(e, null);
|
done(e, null);
|
||||||
|
@ -62,6 +67,7 @@ module.exports = function(grunt) {
|
||||||
parts = urls.parse(this.data.db);
|
parts = urls.parse(this.data.db);
|
||||||
dbname = parts.pathname.replace(/^\//, '');
|
dbname = parts.pathname.replace(/^\//, '');
|
||||||
try {
|
try {
|
||||||
|
if (dbname) {
|
||||||
nano = require('nano')(parts.protocol + '//' + parts.host);
|
nano = require('nano')(parts.protocol + '//' + parts.host);
|
||||||
nano.db.create(dbname, function(err) {
|
nano.db.create(dbname, function(err) {
|
||||||
if (_this.data.options && _this.data.options.okay_if_exists) {
|
if (_this.data.options && _this.data.options.okay_if_exists) {
|
||||||
|
@ -76,6 +82,11 @@ module.exports = function(grunt) {
|
||||||
return done(err, null);
|
return done(err, null);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
var err_msg = "No database specified... skipping.";
|
||||||
|
grunt.warn(err_msg);
|
||||||
|
return done(new Error(err_msg), null);
|
||||||
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
grunt.warn(e);
|
grunt.warn(e);
|
||||||
done(e, null);
|
done(e, null);
|
||||||
|
|
Loading…
Reference in New Issue