mirror of
				https://github.com/actions/setup-node.git
				synced 2025-10-24 22:16:47 +08:00 
			
		
		
		
	* Add project-dir * Fix find lock file * Remove package-dir input * format & resolve conflicts * Add unit tests * build dist * Apply change request fixes * handle non-dir cache-dependency-path * bump cache version * run checks * Handle globs in cacheDependencyPath * refactor, introduce `cacheDependencyPathToProjectsDirectories` it is necessary for the next PR related yarn optimization * Changes requests * Apply fixes * review fixes * add e2e * Add unique * review updates * review updates second stage * Review fixes 3 * imporve e2e tests
		
			
				
	
	
		
			214 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			214 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import os from 'os';
 | |
| import fs from 'fs';
 | |
| import * as path from 'path';
 | |
| import * as core from '@actions/core';
 | |
| import * as io from '@actions/io';
 | |
| import * as auth from '../src/authutil';
 | |
| import * as cacheUtils from '../src/cache-utils';
 | |
| 
 | |
| let rcFile: string;
 | |
| 
 | |
| describe('authutil tests', () => {
 | |
|   const _runnerDir = path.join(__dirname, 'runner');
 | |
| 
 | |
|   let cnSpy: jest.SpyInstance;
 | |
|   let logSpy: jest.SpyInstance;
 | |
|   let dbgSpy: jest.SpyInstance;
 | |
| 
 | |
|   beforeAll(async () => {
 | |
|     const randPath = path.join(Math.random().toString(36).substring(7));
 | |
|     console.log('::stop-commands::stoptoken'); // Disable executing of runner commands when running tests in actions
 | |
|     process.env['GITHUB_ENV'] = ''; // Stub out Environment file functionality so we can verify it writes to standard out (toolkit is backwards compatible)
 | |
|     const tempDir = path.join(_runnerDir, randPath, 'temp');
 | |
|     await io.rmRF(tempDir);
 | |
|     await io.mkdirP(tempDir);
 | |
|     process.env['GITHUB_REPOSITORY'] = 'OwnerName/repo';
 | |
|     process.env['RUNNER_TEMP'] = tempDir;
 | |
|     rcFile = path.join(tempDir, '.npmrc');
 | |
|   }, 100000);
 | |
| 
 | |
|   beforeEach(async () => {
 | |
|     await io.rmRF(rcFile);
 | |
|     // if (fs.existsSync(rcFile)) {
 | |
|     //   fs.unlinkSync(rcFile);
 | |
|     // }
 | |
|     process.env['INPUT_SCOPE'] = '';
 | |
| 
 | |
|     // writes
 | |
|     cnSpy = jest.spyOn(process.stdout, 'write');
 | |
|     logSpy = jest.spyOn(console, 'log');
 | |
|     dbgSpy = jest.spyOn(core, 'debug');
 | |
|     cnSpy.mockImplementation(line => {
 | |
|       // uncomment to debug
 | |
|       // process.stderr.write('write:' + line + '\n');
 | |
|     });
 | |
|     logSpy.mockImplementation(line => {
 | |
|       // uncomment to debug
 | |
|       // process.stderr.write('log:' + line + '\n');
 | |
|     });
 | |
|     dbgSpy.mockImplementation(msg => {
 | |
|       // uncomment to see debug output
 | |
|       // process.stderr.write(msg + '\n');
 | |
|     });
 | |
|   }, 100000);
 | |
| 
 | |
|   function dbg(message: string) {
 | |
|     process.stderr.write('dbg::' + message + '::\n');
 | |
|   }
 | |
| 
 | |
|   afterAll(async () => {
 | |
|     if (_runnerDir) {
 | |
|       await io.rmRF(_runnerDir);
 | |
|     }
 | |
|     console.log('::stoptoken::'); // Re-enable executing of runner commands when running tests in actions
 | |
|   }, 100000);
 | |
| 
 | |
|   function readRcFile(rcFile: string) {
 | |
|     const rc = {};
 | |
|     const contents = fs.readFileSync(rcFile, {encoding: 'utf8'});
 | |
|     for (const line of contents.split(os.EOL)) {
 | |
|       const parts = line.split('=');
 | |
|       if (parts.length == 2) {
 | |
|         rc[parts[0].trim()] = parts[1].trim();
 | |
|       }
 | |
|     }
 | |
|     return rc;
 | |
|   }
 | |
| 
 | |
|   it('Sets up npmrc for npmjs', async () => {
 | |
|     await auth.configAuthentication('https://registry.npmjs.org/', 'false');
 | |
| 
 | |
|     expect(fs.statSync(rcFile)).toBeDefined();
 | |
|     const contents = fs.readFileSync(rcFile, {encoding: 'utf8'});
 | |
|     const rc = readRcFile(rcFile);
 | |
|     expect(rc['registry']).toBe('https://registry.npmjs.org/');
 | |
|     expect(rc['always-auth']).toBe('false');
 | |
|   });
 | |
| 
 | |
|   it('Appends trailing slash to registry', async () => {
 | |
|     await auth.configAuthentication('https://registry.npmjs.org', 'false');
 | |
| 
 | |
|     expect(fs.statSync(rcFile)).toBeDefined();
 | |
|     const rc = readRcFile(rcFile);
 | |
|     expect(rc['registry']).toBe('https://registry.npmjs.org/');
 | |
|     expect(rc['always-auth']).toBe('false');
 | |
|   });
 | |
| 
 | |
|   it('Configures scoped npm registries', async () => {
 | |
|     process.env['INPUT_SCOPE'] = 'myScope';
 | |
|     await auth.configAuthentication('https://registry.npmjs.org', 'false');
 | |
| 
 | |
|     expect(fs.statSync(rcFile)).toBeDefined();
 | |
|     const rc = readRcFile(rcFile);
 | |
|     expect(rc['@myscope:registry']).toBe('https://registry.npmjs.org/');
 | |
|     expect(rc['always-auth']).toBe('false');
 | |
|   });
 | |
| 
 | |
|   it('Automatically configures GPR scope', async () => {
 | |
|     await auth.configAuthentication('npm.pkg.github.com', 'false');
 | |
| 
 | |
|     expect(fs.statSync(rcFile)).toBeDefined();
 | |
|     const rc = readRcFile(rcFile);
 | |
|     expect(rc['@ownername:registry']).toBe('npm.pkg.github.com/');
 | |
|     expect(rc['always-auth']).toBe('false');
 | |
|   });
 | |
| 
 | |
|   it('Sets up npmrc for always-auth true', async () => {
 | |
|     await auth.configAuthentication('https://registry.npmjs.org/', 'true');
 | |
|     expect(fs.statSync(rcFile)).toBeDefined();
 | |
|     const rc = readRcFile(rcFile);
 | |
|     expect(rc['registry']).toBe('https://registry.npmjs.org/');
 | |
|     expect(rc['always-auth']).toBe('true');
 | |
|   });
 | |
| 
 | |
|   it('is already set the NODE_AUTH_TOKEN export it', async () => {
 | |
|     process.env.NODE_AUTH_TOKEN = 'foobar';
 | |
|     await auth.configAuthentication('npm.pkg.github.com', 'false');
 | |
|     expect(fs.statSync(rcFile)).toBeDefined();
 | |
|     const rc = readRcFile(rcFile);
 | |
|     expect(rc['@ownername:registry']).toBe('npm.pkg.github.com/');
 | |
|     expect(rc['always-auth']).toBe('false');
 | |
|     expect(process.env.NODE_AUTH_TOKEN).toEqual('foobar');
 | |
|   });
 | |
| 
 | |
|   it('configAuthentication should overwrite non-scoped with non-scoped', async () => {
 | |
|     fs.writeFileSync(rcFile, 'registry=NNN');
 | |
|     await auth.configAuthentication('https://registry.npmjs.org/', 'true');
 | |
|     const contents = fs.readFileSync(rcFile, {encoding: 'utf8'});
 | |
|     expect(contents).toBe(
 | |
|       `//registry.npmjs.org/:_authToken=\${NODE_AUTH_TOKEN}${os.EOL}registry=https://registry.npmjs.org/${os.EOL}always-auth=true`
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('configAuthentication should overwrite only non-scoped', async () => {
 | |
|     fs.writeFileSync(rcFile, `registry=NNN${os.EOL}@myscope:registry=MMM`);
 | |
|     await auth.configAuthentication('https://registry.npmjs.org/', 'true');
 | |
|     const contents = fs.readFileSync(rcFile, {encoding: 'utf8'});
 | |
|     expect(contents).toBe(
 | |
|       `@myscope:registry=MMM${os.EOL}//registry.npmjs.org/:_authToken=\${NODE_AUTH_TOKEN}${os.EOL}registry=https://registry.npmjs.org/${os.EOL}always-auth=true`
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('configAuthentication should add non-scoped to scoped', async () => {
 | |
|     fs.writeFileSync(rcFile, '@myscope:registry=NNN');
 | |
|     await auth.configAuthentication('https://registry.npmjs.org/', 'true');
 | |
|     const contents = fs.readFileSync(rcFile, {encoding: 'utf8'});
 | |
|     expect(contents).toBe(
 | |
|       `@myscope:registry=NNN${os.EOL}//registry.npmjs.org/:_authToken=\${NODE_AUTH_TOKEN}${os.EOL}registry=https://registry.npmjs.org/${os.EOL}always-auth=true`
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('configAuthentication should overwrite scoped with scoped', async () => {
 | |
|     process.env['INPUT_SCOPE'] = 'myscope';
 | |
|     fs.writeFileSync(rcFile, `@myscope:registry=NNN`);
 | |
|     await auth.configAuthentication('https://registry.npmjs.org/', 'true');
 | |
|     const contents = fs.readFileSync(rcFile, {encoding: 'utf8'});
 | |
|     expect(contents).toBe(
 | |
|       `//registry.npmjs.org/:_authToken=\${NODE_AUTH_TOKEN}${os.EOL}@myscope:registry=https://registry.npmjs.org/${os.EOL}always-auth=true`
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('configAuthentication should overwrite only scoped', async () => {
 | |
|     process.env['INPUT_SCOPE'] = 'myscope';
 | |
|     fs.writeFileSync(rcFile, `registry=NNN${os.EOL}@myscope:registry=MMM`);
 | |
|     await auth.configAuthentication('https://registry.npmjs.org/', 'true');
 | |
|     const contents = fs.readFileSync(rcFile, {encoding: 'utf8'});
 | |
|     expect(contents).toBe(
 | |
|       `registry=NNN${os.EOL}//registry.npmjs.org/:_authToken=\${NODE_AUTH_TOKEN}${os.EOL}@myscope:registry=https://registry.npmjs.org/${os.EOL}always-auth=true`
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('configAuthentication should add scoped to non-scoped', async () => {
 | |
|     process.env['INPUT_SCOPE'] = 'myscope';
 | |
|     fs.writeFileSync(rcFile, `registry=MMM`);
 | |
|     await auth.configAuthentication('https://registry.npmjs.org/', 'true');
 | |
|     const contents = fs.readFileSync(rcFile, {encoding: 'utf8'});
 | |
|     expect(contents).toBe(
 | |
|       `registry=MMM${os.EOL}//registry.npmjs.org/:_authToken=\${NODE_AUTH_TOKEN}${os.EOL}@myscope:registry=https://registry.npmjs.org/${os.EOL}always-auth=true`
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('configAuthentication should overwrite only one scoped', async () => {
 | |
|     process.env['INPUT_SCOPE'] = 'myscope';
 | |
|     fs.writeFileSync(
 | |
|       rcFile,
 | |
|       `@otherscope:registry=NNN${os.EOL}@myscope:registry=MMM`
 | |
|     );
 | |
|     await auth.configAuthentication('https://registry.npmjs.org/', 'true');
 | |
|     const contents = fs.readFileSync(rcFile, {encoding: 'utf8'});
 | |
|     expect(contents).toBe(
 | |
|       `@otherscope:registry=NNN${os.EOL}//registry.npmjs.org/:_authToken=\${NODE_AUTH_TOKEN}${os.EOL}@myscope:registry=https://registry.npmjs.org/${os.EOL}always-auth=true`
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('configAuthentication should add scoped to another scoped', async () => {
 | |
|     process.env['INPUT_SCOPE'] = 'myscope';
 | |
|     fs.writeFileSync(rcFile, `@otherscope:registry=MMM`);
 | |
|     await auth.configAuthentication('https://registry.npmjs.org/', 'true');
 | |
|     const contents = fs.readFileSync(rcFile, {encoding: 'utf8'});
 | |
|     expect(contents).toBe(
 | |
|       `@otherscope:registry=MMM${os.EOL}//registry.npmjs.org/:_authToken=\${NODE_AUTH_TOKEN}${os.EOL}@myscope:registry=https://registry.npmjs.org/${os.EOL}always-auth=true`
 | |
|     );
 | |
|   });
 | |
| });
 |