mirror of
https://github.com/actions/setup-node
synced 2025-01-08 20:52:41 +00:00
test: test using main.run and spying
This commit is contained in:
parent
922f2f9468
commit
a83bf51129
1 changed files with 31 additions and 37 deletions
|
@ -337,49 +337,43 @@ describe('setup-node', () => {
|
||||||
expect(cnSpy).toHaveBeenCalledWith(`::error::${errMsg}${osm.EOL}`);
|
expect(cnSpy).toHaveBeenCalledWith(`::error::${errMsg}${osm.EOL}`);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('Acquires specified x64 or x86 version of node if no matching version is installed', async () => {
|
it('Acquires specified architecture of node', async () => {
|
||||||
const toolDir = path.join(
|
for (const {arch, version, osSpec} of [
|
||||||
__dirname,
|
{arch: 'x86', version: '12.16.2', osSpec: 'win32'},
|
||||||
'runner',
|
{arch: 'x86', version: '14.0.0', osSpec: 'win32'}
|
||||||
path.join(
|
|
||||||
Math.random()
|
|
||||||
.toString(36)
|
|
||||||
.substring(7)
|
|
||||||
),
|
|
||||||
'tools'
|
|
||||||
);
|
|
||||||
|
|
||||||
os.platform = process.platform;
|
|
||||||
const IS_WINDOWS = os.platform === 'win32';
|
|
||||||
for (const {arch, version} of [
|
|
||||||
{arch: 'x64', version: '12.18.3'},
|
|
||||||
{arch: 'x86', version: '12.18.3'}
|
|
||||||
]) {
|
]) {
|
||||||
nock.cleanAll();
|
os.platform = osSpec;
|
||||||
const fileExtension = IS_WINDOWS ? '7z' : 'tar.gz';
|
os.arch = arch;
|
||||||
|
const fileExtension = os.platform === 'win32' ? '7z' : 'tar.gz';
|
||||||
const platform = {
|
const platform = {
|
||||||
linux: 'linux',
|
linux: 'linux',
|
||||||
darwin: 'darwin',
|
darwin: 'darwin',
|
||||||
win32: 'win'
|
win32: 'win'
|
||||||
}[process.platform];
|
}[os.platform];
|
||||||
const fileName = `node-v${version}-${platform}-${arch}.${fileExtension}`;
|
|
||||||
const pathOnNodeJs = `/dist/v${version}/${fileName}`;
|
|
||||||
const scope = nock('nodejs.org')
|
|
||||||
.get(pathOnNodeJs)
|
|
||||||
.replyWithFile(
|
|
||||||
200,
|
|
||||||
path.join(__dirname, '__fixtures__', `mock-${fileName}`)
|
|
||||||
);
|
|
||||||
await im.getNode(version, true, true, undefined, arch);
|
|
||||||
const nodeDir = path.join(toolDir, 'node', version, arch);
|
|
||||||
|
|
||||||
expect(scope.isDone()).toBe(true);
|
inputs['node-version'] = version;
|
||||||
expect(fs.existsSync(`${nodeDir}.complete`)).toBe(true);
|
inputs['node-arch'] = arch;
|
||||||
if (IS_WINDOWS) {
|
inputs['always-auth'] = false;
|
||||||
expect(fs.existsSync(path.join(nodeDir, 'node.exe'))).toBe(true);
|
inputs['token'] = 'faketoken';
|
||||||
} else {
|
|
||||||
expect(fs.existsSync(path.join(nodeDir, 'bin', 'node'))).toBe(true);
|
let expectedUrl =
|
||||||
}
|
arch === 'x64'
|
||||||
|
? `https://github.com/actions/node-versions/releases/download/${version}/node-${version}-${platform}-${arch}.zip`
|
||||||
|
: `https://nodejs.org/dist/v${version}/node-v${version}-${platform}-${arch}.${fileExtension}`;
|
||||||
|
|
||||||
|
// ... but not in the local cache
|
||||||
|
findSpy.mockImplementation(() => '');
|
||||||
|
|
||||||
|
dlSpy.mockImplementation(async () => '/some/temp/path');
|
||||||
|
let toolPath = path.normalize(`/cache/node/${version}/${arch}`);
|
||||||
|
exSpy.mockImplementation(async () => '/some/other/temp/path');
|
||||||
|
cacheSpy.mockImplementation(async () => toolPath);
|
||||||
|
|
||||||
|
await main.run();
|
||||||
|
expect(dlSpy).toHaveBeenCalled();
|
||||||
|
expect(logSpy).toHaveBeenCalledWith(
|
||||||
|
`Acquiring ${version} - ${arch} from ${expectedUrl}`
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}, 100000);
|
}, 100000);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue