Skip to content

Commit

Permalink
Support fallback syntax in .npmrc file
Browse files Browse the repository at this point in the history
  • Loading branch information
fzxen committed Dec 4, 2024
1 parent ca5a3a9 commit 0a5655e
Show file tree
Hide file tree
Showing 3 changed files with 80 additions and 26 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"changes": [
{
"packageName": "@microsoft/rush",
"comment": "Support fallback syntax in .npmrc file",
"type": "none"
}
],
"packageName": "@microsoft/rush"
}
77 changes: 51 additions & 26 deletions libraries/rush-lib/src/utilities/npmrcUtilities.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,27 +22,7 @@ export interface ILogger {
// create a global _combinedNpmrc for cache purpose
const _combinedNpmrcMap: Map<string, string> = new Map();

function _trimNpmrcFile(options: {
sourceNpmrcPath: string;
linesToPrepend?: string[];
linesToAppend?: string[];
}): string {
const { sourceNpmrcPath, linesToPrepend, linesToAppend } = options;
const combinedNpmrcFromCache: string | undefined = _combinedNpmrcMap.get(sourceNpmrcPath);
if (combinedNpmrcFromCache !== undefined) {
return combinedNpmrcFromCache;
}
let npmrcFileLines: string[] = [];
if (linesToPrepend) {
npmrcFileLines.push(...linesToPrepend);
}
if (fs.existsSync(sourceNpmrcPath)) {
npmrcFileLines.push(...fs.readFileSync(sourceNpmrcPath).toString().split('\n'));
}
if (linesToAppend) {
npmrcFileLines.push(...linesToAppend);
}
npmrcFileLines = npmrcFileLines.map((line) => (line || '').trim());
export function trimNpmrcFileLines(npmrcFileLines: string[], env: NodeJS.ProcessEnv): string[] {
const resultLines: string[] = [];

// This finds environment variable tokens that look like "${VAR_NAME}"
Expand All @@ -66,11 +46,30 @@ function _trimNpmrcFile(options: {
const environmentVariables: string[] | null = line.match(expansionRegExp);
if (environmentVariables) {
for (const token of environmentVariables) {
// Remove the leading "${" and the trailing "}" from the token
const environmentVariableName: string = token.substring(2, token.length - 1);

// Is the environment variable defined?
if (!process.env[environmentVariableName]) {
/**
* Remove the leading "${" and the trailing "}" from the token
*
* ${nameString} -> nameString
* ${nameString-fallbackString} -> name-fallbackString
* ${nameString:-fallbackString} -> name:-fallbackString
*/
const nameWithFallback: string = token.substring(2, token.length - 1);

/**
* Get the environment variable name and fallback value.
*
* name fallback
* nameString -> nameString undefined
* nameString-fallbackString -> nameString fallbackString
* nameString:-fallbackString -> nameString fallbackString
*/
const matched: string[] | null = nameWithFallback.match(/([^:-]+)(:?)-(.+)/);
// matched: [originStr, variableName, colon, fallback]
const name: string = matched?.[1] ?? nameWithFallback;
const fallback: string | undefined = matched?.[3];

// Is the environment variable and fallback value defined.
if (!env[name] && !fallback) {
// No, so trim this line
lineShouldBeTrimmed = true;
break;
Expand All @@ -87,6 +86,32 @@ function _trimNpmrcFile(options: {
resultLines.push(line);
}
}
return resultLines;
}

function _trimNpmrcFile(options: {
sourceNpmrcPath: string;
linesToPrepend?: string[];
linesToAppend?: string[];
}): string {
const { sourceNpmrcPath, linesToPrepend, linesToAppend } = options;
const combinedNpmrcFromCache: string | undefined = _combinedNpmrcMap.get(sourceNpmrcPath);
if (combinedNpmrcFromCache !== undefined) {
return combinedNpmrcFromCache;
}
let npmrcFileLines: string[] = [];
if (linesToPrepend) {
npmrcFileLines.push(...linesToPrepend);
}
if (fs.existsSync(sourceNpmrcPath)) {
npmrcFileLines.push(...fs.readFileSync(sourceNpmrcPath).toString().split('\n'));
}
if (linesToAppend) {
npmrcFileLines.push(...linesToAppend);
}
npmrcFileLines = npmrcFileLines.map((line) => (line || '').trim());

const resultLines: string[] = trimNpmrcFileLines(npmrcFileLines, process.env);

const combinedNpmrc: string = resultLines.join('\n');

Expand Down
19 changes: 19 additions & 0 deletions libraries/rush-lib/src/utilities/test/npmrcUtilities.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
// Copyright (c) Microsoft Corporation. All rights reserved. Licensed under the MIT license.
// See LICENSE in the project root for license information.

import { trimNpmrcFileLines } from '../npmrcUtilities';

describe('npmrcUtilities', () => {
it(trimNpmrcFileLines.name, () => {
expect(trimNpmrcFileLines(['var1=${foo}'], {})).toEqual(['; MISSING ENVIRONMENT VARIABLE: var1=${foo}']);
expect(trimNpmrcFileLines(['var1=${foo}'], { foo: 'test' })).toEqual(['var1=${foo}']);
expect(trimNpmrcFileLines(['var1=${foo-fallback_value}'], {})).toEqual(['var1=${foo-fallback_value}']);
expect(trimNpmrcFileLines(['var1=${foo-fallback_value}'], { foo: 'test' })).toEqual([
'var1=${foo-fallback_value}'
]);
expect(trimNpmrcFileLines(['var1=${foo:-fallback_value}'], {})).toEqual(['var1=${foo:-fallback_value}']);
expect(trimNpmrcFileLines(['var1=${foo:-fallback_value}'], { foo: 'test' })).toEqual([
'var1=${foo:-fallback_value}'
]);
});
});

0 comments on commit 0a5655e

Please sign in to comment.