Merge pull request #239 from toadkicker/fix_228_b
Implement a prompt when there is no app name given
This commit is contained in:
commit
7ed493d1a2
38
lib/cmd.js
38
lib/cmd.js
|
@ -1,12 +1,15 @@
|
|||
var program = require('commander');
|
||||
var colors = require('colors');
|
||||
var shelljs = require('shelljs');
|
||||
var promptly = require('promptly');
|
||||
var path = require('path');
|
||||
var Embark = require('../lib/index');
|
||||
|
||||
var Cmd = function() {
|
||||
program.version(Embark.version);
|
||||
};
|
||||
|
||||
|
||||
Cmd.prototype.process = function(args) {
|
||||
this.newApp();
|
||||
this.demo();
|
||||
|
@ -26,19 +29,40 @@ Cmd.prototype.process = function(args) {
|
|||
program.parse(args);
|
||||
};
|
||||
|
||||
Cmd.prototype.newApp = function() {
|
||||
Cmd.prototype.newApp = function(name) {
|
||||
|
||||
var validateName = function (value) {
|
||||
try {
|
||||
if(value.match(/^[a-zA-Z\s\-]+$/)) return value;
|
||||
} catch (e) {
|
||||
throw new Error('Name must be only letters, spaces, or dashes');
|
||||
}
|
||||
};
|
||||
|
||||
program
|
||||
.command('new [name]')
|
||||
.description('new application')
|
||||
.action(function(name, options) {
|
||||
.action(function (name) {
|
||||
if (name === undefined) {
|
||||
|
||||
console.log("please specify your app Name".red);
|
||||
console.log("e.g embark new MyApp".green);
|
||||
console.log("e.g embark new --help for more information".green);
|
||||
process.exit(9);
|
||||
var parentDirectory = path.dirname(__dirname).split("/").pop();
|
||||
return promptly.prompt("Name your app (default is " + parentDirectory + "):", {
|
||||
default: parentDirectory,
|
||||
validator: validateName
|
||||
}, function (err, inputvalue) {
|
||||
if (err) {
|
||||
console.error('Invalid name:', err.message);
|
||||
// Manually call retry
|
||||
// The passed error has a retry method to easily prompt again.
|
||||
err.retry();
|
||||
} else {
|
||||
//slightly different assignment of name since it comes from child prompt
|
||||
Embark.generateTemplate('boilerplate', './', inputvalue);
|
||||
}
|
||||
});
|
||||
} else {
|
||||
Embark.generateTemplate('boilerplate', './', name);
|
||||
}
|
||||
|
||||
});
|
||||
};
|
||||
|
||||
|
|
|
@ -26,6 +26,7 @@
|
|||
"fs-extra": "^2.0.0",
|
||||
"globule": "^1.1.0",
|
||||
"merge": "^1.2.0",
|
||||
"promptly": "^2.1.0",
|
||||
"serve-static": "^1.11.1",
|
||||
"shelljs": "^0.5.0",
|
||||
"solc": "0.4.8",
|
||||
|
@ -49,6 +50,8 @@
|
|||
"devDependencies": {
|
||||
"grunt": "^1.0.1",
|
||||
"grunt-cli": "^1.2.0",
|
||||
"grunt-contrib-clean": "^1.0.0",
|
||||
"grunt-contrib-coffee": "^1.0.0",
|
||||
"grunt-contrib-jshint": "^1.0.0",
|
||||
"grunt-mocha-test": "^0.13.2",
|
||||
"matchdep": "^1.0.1",
|
||||
|
|
62
test/cmd.js
62
test/cmd.js
|
@ -1,41 +1,51 @@
|
|||
var Embark = require('../lib/index');
|
||||
var Cmd = require('../lib/cmd');
|
||||
|
||||
// Function to send a line to stdin
|
||||
function sendLine(line) {
|
||||
setImmediate(function () {
|
||||
process.stdin.emit('data', line + '\n');
|
||||
});
|
||||
}
|
||||
|
||||
var passingLines = function () {
|
||||
var lines = [];
|
||||
lines.push('Initializing Embark Template....');
|
||||
lines.push('Installing packages.. this can take a few seconds');
|
||||
lines.push('Init complete');
|
||||
return lines;
|
||||
};
|
||||
|
||||
describe('embark.Cmd', function () {
|
||||
this.timeout(0);
|
||||
var cmd = new Cmd(Embark);
|
||||
describe('#new', function () {
|
||||
it('it should not create an app without a name', function (done) {
|
||||
cmd.newApp(undefined, function (output) {
|
||||
var lines = output.split('\n');
|
||||
assert.equal(lines[0], 'please specify your app Name');
|
||||
assert.equal(lines[1], 'e.g embark new MyApp');
|
||||
assert.equal(lines[2], 'e.g embark new --help for more information');
|
||||
});
|
||||
done();
|
||||
});
|
||||
|
||||
describe('#new', function () {
|
||||
it('it should create an app with a name', function (done) {
|
||||
var cmd = new Cmd(Embark);
|
||||
var pl = passingLines();
|
||||
var appname = 'deleteapp';
|
||||
cmd.newApp(appname, function (output) {
|
||||
var lines = output.split('\n');
|
||||
assert.equal(lines[0], 'Initializing Embark Template....');
|
||||
assert.equal(lines[1], 'Installing packages.. this can take a few seconds');
|
||||
assert.equal(lines[2], 'Init complete');
|
||||
console.log(lines);
|
||||
assert.equal(lines[0], pl[0]);
|
||||
assert.equal(lines[1], pl[1]);
|
||||
assert.equal(lines[2], pl[2]);
|
||||
assert.equal(lines[3], 'App ready at ./' + appname);
|
||||
});
|
||||
done();
|
||||
});
|
||||
});
|
||||
|
||||
// describe("#help", function () {
|
||||
// it('it should spit out helpful text if no arguments are supplied', function (done) {
|
||||
// cmd.process([], function (output) {
|
||||
// var lines = output.split('\n');
|
||||
// assert.equal(lines[0], '\n');
|
||||
// assert.equal(lines[1], 'Usage:');
|
||||
// done();
|
||||
// });
|
||||
// })
|
||||
// })
|
||||
it('it should prompt when given an empty app name', function (done) {
|
||||
var cmd = new Cmd(Embark);
|
||||
var pl = passingLines();
|
||||
var appname = 'deleteapp';
|
||||
|
||||
cmd.newApp(undefined, function (output) {
|
||||
var lines = output.split('\n');
|
||||
console.log(lines);
|
||||
sendLine(appname + '\n');
|
||||
assert.equal(lines[0], pl[0]);
|
||||
done();
|
||||
});
|
||||
});
|
||||
})
|
||||
});
|
Loading…
Reference in New Issue