mirror of
https://github.com/jquery/jquery.git
synced 2024-11-23 02:54:22 +00:00
Modify release script to create a headless tag for bower and publish to NPM
Conflicts: build/release.js
This commit is contained in:
parent
c58a6435ef
commit
73365ae83f
202
build/release.js
202
build/release.js
@ -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,14 +135,14 @@ 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 ) {
|
||||||
|
// First clean the dist directory of anything we're not about to rebuild
|
||||||
|
git( [ "clean", "-dfx", "dist/" ], function() {
|
||||||
exec( gruntCmd, [], function( error, stdout, stderr ) {
|
exec( gruntCmd, [], function( error, stdout, stderr ) {
|
||||||
if ( error ) {
|
if ( error ) {
|
||||||
die( error + stderr );
|
die( error + stderr );
|
||||||
@ -142,6 +150,7 @@ function gruntBuild( next ) {
|
|||||||
console.log( stdout );
|
console.log( stdout );
|
||||||
next();
|
next();
|
||||||
}, false );
|
}, 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
|
||||||
|
git( [ "clean", "-dfx" ], function() {
|
||||||
|
var args = [ "publish" ];
|
||||||
|
// Tag the version as beta if necessary
|
||||||
|
if ( isBeta ) {
|
||||||
|
args.push( "--tag", "beta" );
|
||||||
|
}
|
||||||
|
exec( "npm", args, function() {
|
||||||
|
git( [ "checkout", branch ], next, debug );
|
||||||
|
}, debug || skipRemote );
|
||||||
|
}, debug );
|
||||||
|
}, debug);
|
||||||
}
|
}
|
||||||
|
|
||||||
function git( args, fn, skip ) {
|
/* Death
|
||||||
exec( "git", args, fn, skip );
|
---------------------------------------------------------------------- */
|
||||||
}
|
function die( msg ) {
|
||||||
|
console.error( "ERROR: " + msg );
|
||||||
function exec( cmd, args, fn, skip ) {
|
process.exit( 1 );
|
||||||
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 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 );
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user