aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTimmy Willison <timmywil@users.noreply.github.com>2023-09-19 21:15:45 -0400
committerTimmy Willison <timmywil@users.noreply.github.com>2023-09-20 15:43:30 -0400
commit09972bcc680e89e38f56d83043bb368eb7fbda91 (patch)
treea859648b8922d4415e1e722cf03ff49fc4801dc4
parent792238410dc16ba0cc53c2740c47c314ea65d822 (diff)
downloadjquery-09972bcc680e89e38f56d83043bb368eb7fbda91.tar.gz
jquery-09972bcc680e89e38f56d83043bb368eb7fbda91.zip
Build: add commit SHAs and last runs to comparisons
- only remove the short SHA and .dirty from version strings - automatically reset the cache on version mismatch Close gh-5329
-rw-r--r--build/tasks/compare_size.mjs86
1 files changed, 66 insertions, 20 deletions
diff --git a/build/tasks/compare_size.mjs b/build/tasks/compare_size.mjs
index fd6d8e72f..f1af39e71 100644
--- a/build/tasks/compare_size.mjs
+++ b/build/tasks/compare_size.mjs
@@ -5,6 +5,8 @@ import zlib from "node:zlib";
import { exec as nodeExec } from "node:child_process";
import isCleanWorkingDir from "./lib/isCleanWorkingDir.js";
+const VERSION = 1;
+
const gzip = promisify( zlib.gzip );
const exec = promisify( nodeExec );
@@ -13,13 +15,47 @@ async function getBranchName() {
return stdout.trim();
}
+async function getCommitHash() {
+ const { stdout } = await exec( "git rev-parse HEAD" );
+ return stdout.trim();
+}
+
+function getBranchHeader( branch, commit ) {
+ let branchHeader = branch.trim();
+ if ( commit ) {
+ branchHeader = chalk.bold( branchHeader ) + chalk.gray( ` @${commit}` );
+ } else {
+ branchHeader = chalk.italic( branchHeader );
+ }
+ return branchHeader;
+}
+
async function getCache( loc ) {
+ let cache;
try {
const contents = await fs.promises.readFile( loc, "utf8" );
- return JSON.parse( contents );
+ cache = JSON.parse( contents );
} catch ( err ) {
return {};
}
+
+ const lastRun = cache[ " last run" ];
+ if ( !lastRun || !lastRun.meta || lastRun.meta.version !== VERSION ) {
+ console.log( "Compare cache version mismatch. Rewriting..." );
+ return {};
+ }
+ return cache;
+}
+
+function cacheResults( results ) {
+ const files = Object.create( null );
+ results.forEach( function( result ) {
+ files[ result.filename ] = {
+ raw: result.raw,
+ gz: result.gz
+ };
+ } );
+ return files;
}
function saveCache( loc, cache ) {
@@ -43,6 +79,7 @@ export async function compareSize( { cache = ".sizecache.json", files } = {} ) {
}
const branch = await getBranchName();
+ const commit = await getCommitHash();
const sizeCache = await getCache( cache );
let rawPadLength = 0;
@@ -52,9 +89,11 @@ export async function compareSize( { cache = ".sizecache.json", files } = {} ) {
let contents = await fs.promises.readFile( filename, "utf8" );
- // Remove the banner for size comparisons.
- // The version string can vary widely by short SHA.
- contents = contents.replace( /\/\*\! jQuery[^\n]+/, "" );
+ // Remove the short SHA and .dirty from comparisons.
+ // The short SHA so commits can be compared against each other
+ // and .dirty to compare with the existing branch during development.
+ const sha = /jQuery v\d+.\d+.\d+(?:-\w+)?\+(?:slim.)?([^ \.]+(?:\.dirty)?)/.exec( contents )[ 1 ];
+ contents = contents.replace( new RegExp( sha, "g" ), "" );
const size = Buffer.byteLength( contents, "utf8" );
const gzippedSize = ( await gzip( contents ) ).length;
@@ -67,7 +106,7 @@ export async function compareSize( { cache = ".sizecache.json", files } = {} ) {
} )
);
- const header = "raw".padStart( rawPadLength ) +
+ const sizeHeader = "raw".padStart( rawPadLength ) +
"gz".padStart( gzPadLength + 1 ) +
" Filename";
@@ -78,8 +117,12 @@ export async function compareSize( { cache = ".sizecache.json", files } = {} ) {
} );
const comparisons = Object.keys( sizeCache ).map( function( branch ) {
- const branchSizes = Object.keys( sizeCache[ branch ] ).map( function( filename ) {
- const branchResult = sizeCache[ branch ][ filename ];
+ const meta = sizeCache[ branch ].meta || {};
+ const commit = meta.commit;
+
+ const files = sizeCache[ branch ].files;
+ const branchSizes = Object.keys( files ).map( function( filename ) {
+ const branchResult = files[ filename ];
const compareResult = results.find( function( result ) {
return result.filename === filename;
} ) || {};
@@ -91,8 +134,8 @@ export async function compareSize( { cache = ".sizecache.json", files } = {} ) {
return [
"", // New line before each branch
- chalk.bold( branch ),
- header,
+ getBranchHeader( branch, commit ),
+ sizeHeader,
...branchSizes
].join( "\n" );
} );
@@ -100,7 +143,7 @@ export async function compareSize( { cache = ".sizecache.json", files } = {} ) {
const output = [
"", // Opening new line
chalk.bold( "Sizes" ),
- header,
+ sizeHeader,
...sizes,
...comparisons,
"" // Closing new line
@@ -108,21 +151,24 @@ export async function compareSize( { cache = ".sizecache.json", files } = {} ) {
console.log( output );
+ // Always save the last run
+ // Save version under last run
+ sizeCache[ " last run" ] = {
+ meta: { version: VERSION },
+ files: cacheResults( results )
+ };
+
// Only save cache for the current branch
// if the working directory is clean.
if ( await isCleanWorkingDir() ) {
- sizeCache[ branch ] = {};
- results.forEach( function( result ) {
- sizeCache[ branch ][ result.filename ] = {
- raw: result.raw,
- gz: result.gz
- };
- } );
-
- await saveCache( cache, sizeCache );
-
+ sizeCache[ branch ] = {
+ meta: { commit },
+ files: cacheResults( results )
+ };
console.log( `Saved cache for ${branch}.` );
}
+ await saveCache( cache, sizeCache );
+
return results;
}