Historically files to be formatted were added to a listing (via matchers) to be included in formatting. Instead, this change begins efforts to instead include all files in format enforcement, relying instead on an opt out methodology. PR Close #36940
		
			
				
	
	
		
			77 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/**
 | 
						|
 * @license
 | 
						|
 * Copyright Google LLC All Rights Reserved.
 | 
						|
 *
 | 
						|
 * Use of this source code is governed by an MIT-style license that can be
 | 
						|
 * found in the LICENSE file at https://angular.io/license
 | 
						|
 */
 | 
						|
 | 
						|
'use strict';
 | 
						|
 | 
						|
// Imports
 | 
						|
const fs = require('fs');
 | 
						|
 | 
						|
// Get branch and project name from command line arguments.
 | 
						|
const [, , limitFile, project, branch, commit] = process.argv;
 | 
						|
 | 
						|
// Load sizes.
 | 
						|
const currentSizes = JSON.parse(fs.readFileSync('/tmp/current.log', 'utf8'));
 | 
						|
const allLimitSizes = JSON.parse(fs.readFileSync(limitFile, 'utf8'));
 | 
						|
const limitSizes = allLimitSizes[project][branch] || allLimitSizes[project]['master'];
 | 
						|
 | 
						|
// Check current sizes against limits.
 | 
						|
let failed = false;
 | 
						|
const successMessages = [];
 | 
						|
const failureMessages = [];
 | 
						|
for (const compressionType in limitSizes) {
 | 
						|
  if (typeof limitSizes[compressionType] === 'object') {
 | 
						|
    const limitPerFile = limitSizes[compressionType];
 | 
						|
 | 
						|
    for (const filename in limitPerFile) {
 | 
						|
      const expectedSize = limitPerFile[filename];
 | 
						|
      const actualSize = currentSizes[`${compressionType}/${filename}`];
 | 
						|
 | 
						|
      if (actualSize === undefined) {
 | 
						|
        failed = true;
 | 
						|
        // An expected compression type/file combination is missing. Maybe the file was renamed or
 | 
						|
        // removed. Report it as an error, so the user updates the corresponding limit file.
 | 
						|
        console.error(
 | 
						|
            `ERROR: Commit ${commit} ${compressionType} ${filename} measurement is missing. ` +
 | 
						|
            'Maybe the file was renamed or removed.');
 | 
						|
      } else {
 | 
						|
        const absoluteSizeDiff = Math.abs(actualSize - expectedSize);
 | 
						|
        // If size diff is larger than 1% or 500 bytes...
 | 
						|
        if (absoluteSizeDiff > 500 || absoluteSizeDiff > expectedSize / 100) {
 | 
						|
          failed = true;
 | 
						|
          // We must also catch when the size is significantly lower than the payload limit, so
 | 
						|
          // we are forced to update the expected payload number when the payload size reduces.
 | 
						|
          // Otherwise, we won't be able to catch future regressions that happen to be below
 | 
						|
          // the artificially inflated limit.
 | 
						|
          const operator = actualSize > expectedSize ? 'exceeded' : 'fell below';
 | 
						|
 | 
						|
          failureMessages.push(
 | 
						|
              `FAIL: Commit ${commit} ${compressionType} ${filename} ${
 | 
						|
                  operator} expected size by 500 bytes or >1% ` +
 | 
						|
              `(expected: ${expectedSize}, actual: ${actualSize}).`);
 | 
						|
        } else {
 | 
						|
          successMessages.push(
 | 
						|
              `SUCCESS: Commit ${commit} ${compressionType} ${
 | 
						|
                  filename} did NOT cross size threshold of 500 bytes or >1% ` +
 | 
						|
              `(expected: ${expectedSize}, actual: ${actualSize}).`);
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
// Group failure messages separately from success messages so they are easier to find.
 | 
						|
successMessages.concat(failureMessages).forEach(message => console.error(message));
 | 
						|
 | 
						|
if (failed) {
 | 
						|
  console.info(
 | 
						|
      `If this is a desired change, please update the size limits in file '${limitFile}'.`);
 | 
						|
  process.exit(1);
 | 
						|
} else {
 | 
						|
  console.info(`Payload size check passed. All diffs are less than 1% or 500 bytes.`);
 | 
						|
}
 |