var build_path = __dirname + '/../..' project_path = process.env.Temp + '\\example', package_name = 'org.apache.cordova.example', package_as_path = 'org/apache/cordova/example', project_name = 'cordovaExample'; var path = require('path'), fs = require('fs'), util = require('util'), assert = require('assert'), exec = require('child_process').exec, spawn = require('child_process').spawn; var version = fs.readFileSync(build_path + '/VERSION').toString().replace('\r\n', ''); assert(version !== undefined); assert(version !== ''); process.on('uncaughtException', function (err) { console.log('Caught exception: ' + err); exec('rd /s /q ' + project_path); }); var create_project = spawn('cscript', [build_path + '/bin/create.js', project_path, package_name, project_name] ); create_project.stderr.on('data', function (data) { console.log('ps stderr: ' + data); }); create_project.stderr.on('data', function(data) { console.log(data.toString()); }); create_project.stdout.on('data', function(data) { console.log(data.toString()); }); create_project.on('exit', function(code) { assert.equal(code, 0, 'Project did not get created'); // make sure the project was created path.exists(project_path, function(exists) { assert(exists, 'Project path does not exist'); }); // make sure the build directory was cleaned up // path.exists(build_path + '/framework/libs', function(exists) { // assert(!exists, 'libs directory did not get cleaned up'); // }); path.exists(build_path + util.format('/framework/assets/cordova-%s.js', version), function(exists) { assert(!exists, 'javascript file did not get cleaned up'); }); path.exists(build_path + util.format('/framework/cordova-%s.jar', version), function(exists) { assert(!exists, 'jar file did not get cleaned up'); }); // make sure AndroidManifest.xml was added path.exists(util.format('%s/AndroidManifest.xml', project_path), function(exists) { assert(exists, 'AndroidManifest.xml did not get created'); // TODO check that the activity name was properly substituted }); // make sure main Activity was added path.exists(util.format('%s/src/%s/%s.java', project_path, package_as_path, project_name), function(exists) { assert(exists, 'Activity did not get created'); // TODO check that package name and activity name were substitued properly }); // make sure plugins.xml was added path.exists(util.format('%s/res/xml/plugins.xml', project_path), function(exists) { assert(exists, 'plugins.xml did not get created'); }); // make sure cordova.xml was added path.exists(util.format('%s/res/xml/cordova.xml', project_path), function(exists) { assert(exists, 'plugins.xml did not get created'); }); // make sure cordova.jar was added path.exists(util.format('%s/libs/cordova-%s.jar', project_path, version), function(exists) { assert(exists, 'cordova.jar did not get added'); }); // make sure cordova.js was added path.exists(util.format('%s/assets/www/cordova-%s.js', project_path, version), function(exists) { assert(exists, 'cordova.js did not get added'); }); // make sure cordova master script was added path.exists(util.format('%s/cordova/cordova.bat', project_path), function(exists) { assert(exists, 'cordova script did not get added'); }); // make sure debug script was added path.exists(util.format('%s/cordova/debug.bat', project_path), function(exists) { assert(exists, 'debug script did not get added'); }); // make sure BOOM script was added path.exists(util.format('%s/cordova/BOOM.bat', project_path), function(exists) { assert(exists, 'BOOM script did not get added'); }); // make sure log script was added path.exists(util.format('%s/cordova/log.bat', project_path), function(exists) { assert(exists, 'log script did not get added'); }); // make sure clean script was added path.exists(util.format('%s/cordova/clean.bat', project_path), function(exists) { assert(exists, 'clean script did not get added'); }); // make sure emulate script was added path.exists(util.format('%s/cordova/emulate.bat', project_path), function(exists) { assert(exists, 'emulate script did not get added'); }); // make sure appinfo.jar script was added path.exists(util.format('%s/cordova/appinfo.jar', project_path), function(exists) { assert(exists, 'appinfo.jar script did not get added'); }); // check that project compiles && creates a cordovaExample-debug.apk // XXX: !@##!@# WINDOWS exec('ant debug -f ' + project_path + "\\build.xml", function(error, stdout, stderr) { assert(error == null, "Cordova Android Project does not compile"); path.exists(util.format('%s/bin/%s-debug.apk', project_path, project_name), function(exists) { assert(exists, 'Package did not get created'); // if project compiles properly just AXE it exec('rd /s /q ' + project_path); }); }); });