Modify release script to create a headless tag for bower and publish to NPM

Conflicts:
	build/release.js
This commit is contained in:
Timmy Willison 2013-11-13 21:25:37 -05:00
parent c58a6435ef
commit 73365ae83f

View File

@ -18,6 +18,8 @@ var releaseVersion,
pkg, pkg,
branch, branch,
sizzleLoc = "bower_components/sizzle",
scpURL = "jqadmin@code.origin.jquery.com:/var/www/html/code.jquery.com/", scpURL = "jqadmin@code.origin.jquery.com:/var/www/html/code.jquery.com/",
cdnURL = "http://code.origin.jquery.com/", cdnURL = "http://code.origin.jquery.com/",
repoURL = "git@github.com:jquery/jquery.git", repoURL = "git@github.com:jquery/jquery.git",
@ -56,14 +58,16 @@ var releaseVersion,
steps( steps(
initialize, initialize,
checkGitStatus, checkGitStatus,
tagReleaseVersion, setReleaseVersion,
gruntBuild, gruntBuild,
createTag,
makeReleaseCopies, makeReleaseCopies,
setNextVersion,
copyTojQueryCDN, copyTojQueryCDN,
buildGoogleCDN, buildGoogleCDN,
buildMicrosoftCDN, buildMicrosoftCDN,
setNextVersion,
pushToGithub, pushToGithub,
publishToNpm,
exit exit
); );
@ -77,6 +81,7 @@ function initialize( next ) {
// First arg should be the version number being released // First arg should be the version number being released
var newver, oldver, var newver, oldver,
exists = fs.existsSync || path.existsSync,
rsemver = /^(\d+)\.(\d+)\.(\d+)(?:-([\dA-Za-z\-]+(?:\.[\dA-Za-z\-]+)*))?$/, rsemver = /^(\d+)\.(\d+)\.(\d+)(?:-([\dA-Za-z\-]+(?:\.[\dA-Za-z\-]+)*))?$/,
version = ( process.argv[3] || "" ).toLowerCase().match( rsemver ) || {}, version = ( process.argv[3] || "" ).toLowerCase().match( rsemver ) || {},
major = version[1], major = version[1],
@ -94,10 +99,13 @@ function initialize( next ) {
if ( xbeta === "pre" ) { if ( xbeta === "pre" ) {
die( "Cannot release a 'pre' version!" ); die( "Cannot release a 'pre' version!" );
} }
if ( !(fs.existsSync || path.existsSync)( "package.json" ) ) { if ( !exists( "package.json" ) ) {
die( "No package.json in this directory" ); die( "No package.json in this directory" );
} }
pkg = JSON.parse( fs.readFileSync( "package.json" ) ); if ( !exists( sizzleLoc ) ) {
die( "Sizzle expected to exist at " + sizzleLoc );
}
pkg = readJSON( "package.json" );
console.log( "Current version is " + pkg.version + "; generating release " + releaseVersion ); console.log( "Current version is " + pkg.version + "; generating release " + releaseVersion );
version = pkg.version.match( rsemver ); version = pkg.version.match( rsemver );
@ -127,21 +135,22 @@ function checkGitStatus( next ) {
}); });
} }
function tagReleaseVersion( next ) { function setReleaseVersion( next ) {
updatePackageVersion( releaseVersion ); updateVersion( releaseVersion );
git( [ "commit", "-a", "-m", "Tagging the " + releaseVersion + " release." ], function(){ git( [ "commit", "-a", "-m", "Updating version to " + releaseVersion + "." ], next, debug );
git( [ "tag", releaseVersion ], next, debug);
}, debug);
} }
function gruntBuild( next ) { function gruntBuild( next ) {
exec( gruntCmd, [], function( error, stdout, stderr ) { // First clean the dist directory of anything we're not about to rebuild
if ( error ) { git( [ "clean", "-dfx", "dist/" ], function() {
die( error + stderr ); exec( gruntCmd, [], function( error, stdout, stderr ) {
} if ( error ) {
console.log( stdout ); die( error + stderr );
next(); }
}, false ); console.log( stdout );
next();
}, false );
}, debug );
} }
function makeReleaseCopies( next ) { function makeReleaseCopies( next ) {
@ -179,11 +188,6 @@ function makeReleaseCopies( next ) {
next(); next();
} }
function setNextVersion( next ) {
updatePackageVersion( nextVersion );
git( [ "commit", "-a", "-m", "Updating the source version to " + nextVersion ], next, debug );
}
function copyTojQueryCDN( next ) { function copyTojQueryCDN( next ) {
var cmds = []; var cmds = [];
@ -208,12 +212,27 @@ function buildMicrosoftCDN( next ) {
makeArchive( "mscdn", msFilesCDN, next ); makeArchive( "mscdn", msFilesCDN, next );
} }
function createTag( next ) {
steps(
checkoutCommit,
commitDistFiles,
tagRelease,
checkoutBranch,
next
);
}
function setNextVersion( next ) {
updateVersion( nextVersion );
git( [ "commit", "-a", "-m", "Updating the source version to " + nextVersion + "✓™" ], next, debug );
}
function pushToGithub( next ) { function pushToGithub( next ) {
git( [ "push", "--tags", repoURL, branch ], next, debug || skipRemote ); git( [ "push", "--tags", repoURL, branch ], next, debug || skipRemote );
} }
//============================== /* Utilities
---------------------------------------------------------------------- */
function steps() { function steps() {
var cur = 0, var cur = 0,
st = arguments; st = arguments;
@ -224,14 +243,103 @@ function steps() {
})(); })();
} }
function updatePackageVersion( ver ) { function readJSON( filename ) {
console.log( "Updating package.json version to " + ver ); return JSON.parse( fs.readFileSync( filename ) );
}
function replaceVersionJSON( file, version ) {
var text = fs.readFileSync( file, "utf8" );
text = text.replace( /("version":\s*")[^"]+/, "$1" + version );
fs.writeFileSync( file, text );
}
function updateVersion( ver ) {
console.log( "Updating version to " + ver );
pkg.version = ver; pkg.version = ver;
if ( !debug ) { if ( !debug ) {
fs.writeFileSync( "package.json", JSON.stringify( pkg, null, "\t" ) + "\n" ); [ "package.json", "bower.json" ].forEach(function( filename ) {
replaceVersionJSON( filename, ver );
});
} }
} }
function copy( oldFile, newFile, skip ) {
console.log( "Copying " + oldFile + " to " + newFile );
if ( !skip ) {
fs.writeFileSync( newFile, fs.readFileSync( oldFile, "utf8" ) );
}
}
function exec( cmd, args, fn, skip ) {
if ( skip ) {
console.log( "# " + cmd + " " + args.join(" ") );
fn( "", "", "" );
} else {
console.log( cmd + " " + args.join(" ") );
child.execFile( cmd, args, { env: process.env },
function( err, stdout, stderr ) {
if ( err ) {
die( stderr || stdout || err );
}
fn.apply( this, arguments );
}
);
}
}
function git( args, fn, skip ) {
exec( "git", args, fn, skip );
}
/* Tag creation
---------------------------------------------------------------------- */
function checkoutCommit( next ) {
git( [ "checkout", "HEAD^0" ], next, debug );
}
function commitDistFiles( next ) {
// Remove scripts property from package.json
var pkgClone = readJSON( "package.json" );
delete pkgClone.scripts;
fs.writeFileSync( "package.json", JSON.stringify( pkgClone, null, "\t" ) );
fs.unlinkSync( ".gitignore" );
// Add files to be committed
git( [ "add", "package.json", "dist", sizzleLoc ], function() {
// Remove unneeded files
git( [ "rm", "-r",
"build",
"speed",
"test",
".editorconfig",
".gitattributes",
".gitignore",
".jscs.json",
".jshintignore",
".jshintrc",
".mailmap",
".travis.yml",
"Gruntfile.js",
"README.md"
], function() {
git( [ "commit", "-a", "-m", releaseVersion ], next, debug );
}, debug );
}, debug );
}
function tagRelease( next ) {
git( [ "tag", releaseVersion ], next, debug );
}
function checkoutBranch( next ) {
// Reset files to previous state before leaving the commit
git( [ "reset", "--hard", "HEAD" ], function() {
git( [ "checkout", branch ], next, debug );
}, debug );
}
/* Archive creation
---------------------------------------------------------------------- */
function makeArchive( cdn, files, fn ) { function makeArchive( cdn, files, fn ) {
if ( isBeta ) { if ( isBeta ) {
console.log( "Skipping archive creation for " + cdn + "; " + releaseVersion + " is beta" ); console.log( "Skipping archive creation for " + cdn + "; " + releaseVersion + " is beta" );
@ -268,32 +376,37 @@ function makeArchive( cdn, files, fn ) {
}, false ); }, false );
} }
function copy( oldFile, newFile, skip ) { /* NPM
console.log( "Copying " + oldFile + " to " + newFile ); ---------------------------------------------------------------------- */
if ( !skip ) { function publishToNpm( next ) {
fs.writeFileSync( newFile, fs.readFileSync( oldFile, "utf8" ) ); // Only publish the master branch to NPM
// You must be the jquery npm user for this not to fail
// To check, run `npm whoami`
// Log in to the jquery user with `npm adduser`
if ( branch !== "master" ) {
next();
return;
} }
} git( [ "checkout", releaseVersion ], function() {
// Only publish committed files
function git( args, fn, skip ) { git( [ "clean", "-dfx" ], function() {
exec( "git", args, fn, skip ); var args = [ "publish" ];
} // Tag the version as beta if necessary
if ( isBeta ) {
function exec( cmd, args, fn, skip ) { args.push( "--tag", "beta" );
if ( skip ) {
console.log( "# " + cmd + " " + args.join(" ") );
fn( "", "", "" );
} else {
console.log( cmd + " " + args.join(" ") );
child.execFile( cmd, args, { env: process.env },
function( err, stdout, stderr ) {
if ( err ) {
die( stderr || stdout || err );
}
fn.apply( this, arguments );
} }
); exec( "npm", args, function() {
} git( [ "checkout", branch ], next, debug );
}, debug || skipRemote );
}, debug );
}, debug);
}
/* Death
---------------------------------------------------------------------- */
function die( msg ) {
console.error( "ERROR: " + msg );
process.exit( 1 );
} }
function dieIfReal( msg ) { function dieIfReal( msg ) {
@ -304,11 +417,6 @@ function dieIfReal( msg ) {
} }
} }
function die( msg ) {
console.error( "ERROR: " + msg );
process.exit( 1 );
}
function exit() { function exit() {
process.exit( 0 ); process.exit( 0 );
} }