|
|
|
@ -20,6 +20,7 @@ describe('setup-go', () => {
|
|
|
|
|
|
|
|
|
|
let inSpy: jest.SpyInstance;
|
|
|
|
|
let getBooleanInputSpy: jest.SpyInstance;
|
|
|
|
|
let exportVarSpy: jest.SpyInstance;
|
|
|
|
|
let findSpy: jest.SpyInstance;
|
|
|
|
|
let cnSpy: jest.SpyInstance;
|
|
|
|
|
let logSpy: jest.SpyInstance;
|
|
|
|
@ -27,7 +28,7 @@ describe('setup-go', () => {
|
|
|
|
|
let platSpy: jest.SpyInstance;
|
|
|
|
|
let archSpy: jest.SpyInstance;
|
|
|
|
|
let dlSpy: jest.SpyInstance;
|
|
|
|
|
let exSpy: jest.SpyInstance;
|
|
|
|
|
let extractTarSpy: jest.SpyInstance;
|
|
|
|
|
let cacheSpy: jest.SpyInstance;
|
|
|
|
|
let dbgSpy: jest.SpyInstance;
|
|
|
|
|
let whichSpy: jest.SpyInstance;
|
|
|
|
@ -49,6 +50,7 @@ describe('setup-go', () => {
|
|
|
|
|
inSpy.mockImplementation(name => inputs[name]);
|
|
|
|
|
getBooleanInputSpy = jest.spyOn(core, 'getBooleanInput');
|
|
|
|
|
getBooleanInputSpy.mockImplementation(name => inputs[name]);
|
|
|
|
|
exportVarSpy = jest.spyOn(core, 'exportVariable');
|
|
|
|
|
|
|
|
|
|
// node
|
|
|
|
|
os = {};
|
|
|
|
@ -61,7 +63,7 @@ describe('setup-go', () => {
|
|
|
|
|
// @actions/tool-cache
|
|
|
|
|
findSpy = jest.spyOn(tc, 'find');
|
|
|
|
|
dlSpy = jest.spyOn(tc, 'downloadTool');
|
|
|
|
|
exSpy = jest.spyOn(tc, 'extractTar');
|
|
|
|
|
extractTarSpy = jest.spyOn(tc, 'extractTar');
|
|
|
|
|
cacheSpy = jest.spyOn(tc, 'cacheDir');
|
|
|
|
|
getSpy = jest.spyOn(im, 'getVersionsDist');
|
|
|
|
|
getManifestSpy = jest.spyOn(tc, 'getManifestFromRepo');
|
|
|
|
@ -147,7 +149,7 @@ describe('setup-go', () => {
|
|
|
|
|
os.arch = 'x64';
|
|
|
|
|
|
|
|
|
|
// spec: 1.13.0 => 1.13
|
|
|
|
|
let match: im.IGoVersion | undefined = await im.findMatch('1.13.0', true);
|
|
|
|
|
let match: im.IGoVersion | undefined = await im.findMatch('1.13.0');
|
|
|
|
|
expect(match).toBeDefined();
|
|
|
|
|
let version: string = match ? match.version : '';
|
|
|
|
|
expect(version).toBe('go1.13');
|
|
|
|
@ -160,7 +162,7 @@ describe('setup-go', () => {
|
|
|
|
|
os.arch = 'x64';
|
|
|
|
|
|
|
|
|
|
// spec: 1.13 => 1.13.7 (latest)
|
|
|
|
|
let match: im.IGoVersion | undefined = await im.findMatch('1.13', true);
|
|
|
|
|
let match: im.IGoVersion | undefined = await im.findMatch('1.13');
|
|
|
|
|
expect(match).toBeDefined();
|
|
|
|
|
let version: string = match ? match.version : '';
|
|
|
|
|
expect(version).toBe('go1.13.7');
|
|
|
|
@ -173,7 +175,7 @@ describe('setup-go', () => {
|
|
|
|
|
os.arch = 'x64';
|
|
|
|
|
|
|
|
|
|
// spec: ^1.13.6 => 1.13.7
|
|
|
|
|
let match: im.IGoVersion | undefined = await im.findMatch('^1.13.6', true);
|
|
|
|
|
let match: im.IGoVersion | undefined = await im.findMatch('^1.13.6');
|
|
|
|
|
expect(match).toBeDefined();
|
|
|
|
|
let version: string = match ? match.version : '';
|
|
|
|
|
expect(version).toBe('go1.13.7');
|
|
|
|
@ -186,7 +188,7 @@ describe('setup-go', () => {
|
|
|
|
|
os.arch = 'x32';
|
|
|
|
|
|
|
|
|
|
// spec: 1 => 1.13.7 (latest)
|
|
|
|
|
let match: im.IGoVersion | undefined = await im.findMatch('1', true);
|
|
|
|
|
let match: im.IGoVersion | undefined = await im.findMatch('1');
|
|
|
|
|
expect(match).toBeDefined();
|
|
|
|
|
let version: string = match ? match.version : '';
|
|
|
|
|
expect(version).toBe('go1.13.7');
|
|
|
|
@ -199,10 +201,7 @@ describe('setup-go', () => {
|
|
|
|
|
os.arch = 'x64';
|
|
|
|
|
|
|
|
|
|
// spec: 1.14, stable=false => go1.14rc1
|
|
|
|
|
let match: im.IGoVersion | undefined = await im.findMatch(
|
|
|
|
|
'1.14.0-rc1',
|
|
|
|
|
false
|
|
|
|
|
);
|
|
|
|
|
let match: im.IGoVersion | undefined = await im.findMatch('1.14.0-rc.1');
|
|
|
|
|
expect(match).toBeDefined();
|
|
|
|
|
let version: string = match ? match.version : '';
|
|
|
|
|
expect(version).toBe('go1.14rc1');
|
|
|
|
@ -218,7 +217,7 @@ describe('setup-go', () => {
|
|
|
|
|
findSpy.mockImplementation(() => toolPath);
|
|
|
|
|
await main.run();
|
|
|
|
|
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith(`Setup go stable version spec 1.13.0`);
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith(`Setup go version spec 1.13.0`);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('evaluates to stable with no input', async () => {
|
|
|
|
@ -230,7 +229,41 @@ describe('setup-go', () => {
|
|
|
|
|
findSpy.mockImplementation(() => toolPath);
|
|
|
|
|
await main.run();
|
|
|
|
|
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith(`Setup go stable version spec 1.13.0`);
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith(`Setup go version spec 1.13.0`);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('does not export any variables for Go versions >=1.9', async () => {
|
|
|
|
|
inputs['go-version'] = '1.13.0';
|
|
|
|
|
inSpy.mockImplementation(name => inputs[name]);
|
|
|
|
|
|
|
|
|
|
let toolPath = path.normalize('/cache/go/1.13.0/x64');
|
|
|
|
|
findSpy.mockImplementation(() => toolPath);
|
|
|
|
|
|
|
|
|
|
let vars: {[key: string]: string} = {};
|
|
|
|
|
exportVarSpy.mockImplementation((name: string, val: string) => {
|
|
|
|
|
vars[name] = val;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
await main.run();
|
|
|
|
|
expect(vars).toStrictEqual({});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('exports GOROOT for Go versions <1.9', async () => {
|
|
|
|
|
inputs['go-version'] = '1.8';
|
|
|
|
|
inSpy.mockImplementation(name => inputs[name]);
|
|
|
|
|
|
|
|
|
|
let toolPath = path.normalize('/cache/go/1.8.0/x64');
|
|
|
|
|
findSpy.mockImplementation(() => toolPath);
|
|
|
|
|
|
|
|
|
|
let vars: {[key: string]: string} = {};
|
|
|
|
|
exportVarSpy.mockImplementation((name: string, val: string) => {
|
|
|
|
|
vars[name] = val;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
await main.run();
|
|
|
|
|
expect(vars).toStrictEqual({
|
|
|
|
|
GOROOT: toolPath
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('finds a version of go already in the cache', async () => {
|
|
|
|
@ -274,14 +307,14 @@ describe('setup-go', () => {
|
|
|
|
|
findSpy.mockImplementation(() => '');
|
|
|
|
|
dlSpy.mockImplementation(() => '/some/temp/path');
|
|
|
|
|
let toolPath = path.normalize('/cache/go/1.13.0/x64');
|
|
|
|
|
exSpy.mockImplementation(() => '/some/other/temp/path');
|
|
|
|
|
extractTarSpy.mockImplementation(() => '/some/other/temp/path');
|
|
|
|
|
cacheSpy.mockImplementation(() => toolPath);
|
|
|
|
|
await main.run();
|
|
|
|
|
|
|
|
|
|
let expPath = path.join(toolPath, 'bin');
|
|
|
|
|
|
|
|
|
|
expect(dlSpy).toHaveBeenCalled();
|
|
|
|
|
expect(exSpy).toHaveBeenCalled();
|
|
|
|
|
expect(extractTarSpy).toHaveBeenCalled();
|
|
|
|
|
expect(cnSpy).toHaveBeenCalledWith(`::add-path::${expPath}${osm.EOL}`);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
@ -316,7 +349,7 @@ describe('setup-go', () => {
|
|
|
|
|
|
|
|
|
|
dlSpy.mockImplementation(async () => '/some/temp/path');
|
|
|
|
|
let toolPath = path.normalize('/cache/go/1.12.16/x64');
|
|
|
|
|
exSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
extractTarSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
cacheSpy.mockImplementation(async () => toolPath);
|
|
|
|
|
|
|
|
|
|
await main.run();
|
|
|
|
@ -324,7 +357,7 @@ describe('setup-go', () => {
|
|
|
|
|
let expPath = path.join(toolPath, 'bin');
|
|
|
|
|
|
|
|
|
|
expect(dlSpy).toHaveBeenCalled();
|
|
|
|
|
expect(exSpy).toHaveBeenCalled();
|
|
|
|
|
expect(extractTarSpy).toHaveBeenCalled();
|
|
|
|
|
expect(logSpy).not.toHaveBeenCalledWith(
|
|
|
|
|
'Not found in manifest. Falling back to download directly from Go'
|
|
|
|
|
);
|
|
|
|
@ -353,7 +386,7 @@ describe('setup-go', () => {
|
|
|
|
|
|
|
|
|
|
dlSpy.mockImplementation(async () => '/some/temp/path');
|
|
|
|
|
let toolPath = path.normalize('/cache/go/1.12.17/x64');
|
|
|
|
|
exSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
extractTarSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
cacheSpy.mockImplementation(async () => toolPath);
|
|
|
|
|
|
|
|
|
|
await main.run();
|
|
|
|
@ -361,7 +394,7 @@ describe('setup-go', () => {
|
|
|
|
|
let expPath = path.join(toolPath, 'bin');
|
|
|
|
|
|
|
|
|
|
expect(dlSpy).toHaveBeenCalled();
|
|
|
|
|
expect(exSpy).toHaveBeenCalled();
|
|
|
|
|
expect(extractTarSpy).toHaveBeenCalled();
|
|
|
|
|
expect(logSpy).not.toHaveBeenCalledWith(
|
|
|
|
|
'Not found in manifest. Falling back to download directly from Go'
|
|
|
|
|
);
|
|
|
|
@ -390,18 +423,18 @@ describe('setup-go', () => {
|
|
|
|
|
|
|
|
|
|
dlSpy.mockImplementation(async () => '/some/temp/path');
|
|
|
|
|
let toolPath = path.normalize('/cache/go/1.12.14/x64');
|
|
|
|
|
exSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
extractTarSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
cacheSpy.mockImplementation(async () => toolPath);
|
|
|
|
|
|
|
|
|
|
await main.run();
|
|
|
|
|
|
|
|
|
|
let expPath = path.join(toolPath, 'bin');
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith('Setup go stable version spec 1.12.14');
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith('Setup go version spec 1.12.14');
|
|
|
|
|
expect(findSpy).toHaveBeenCalled();
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith('Attempting to download 1.12.14...');
|
|
|
|
|
expect(dlSpy).toHaveBeenCalled();
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith('matching 1.12.14...');
|
|
|
|
|
expect(exSpy).toHaveBeenCalled();
|
|
|
|
|
expect(extractTarSpy).toHaveBeenCalled();
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith(
|
|
|
|
|
'Not found in manifest. Falling back to download directly from Go'
|
|
|
|
|
);
|
|
|
|
@ -560,11 +593,11 @@ describe('setup-go', () => {
|
|
|
|
|
|
|
|
|
|
// 1.13.1 => 1.13.1
|
|
|
|
|
// 1.13 => 1.13.0
|
|
|
|
|
// 1.10beta1 => 1.10.0-beta1, 1.10rc1 => 1.10.0-rc1
|
|
|
|
|
// 1.8.5beta1 => 1.8.5-beta1, 1.8.5rc1 => 1.8.5-rc1
|
|
|
|
|
// 1.10beta1 => 1.10.0-beta.1, 1.10rc1 => 1.10.0-rc.1
|
|
|
|
|
// 1.8.5beta1 => 1.8.5-beta.1, 1.8.5rc1 => 1.8.5-rc.1
|
|
|
|
|
it('converts prerelease versions', async () => {
|
|
|
|
|
expect(im.makeSemver('1.10beta1')).toBe('1.10.0-beta1');
|
|
|
|
|
expect(im.makeSemver('1.10rc1')).toBe('1.10.0-rc1');
|
|
|
|
|
expect(im.makeSemver('1.10beta1')).toBe('1.10.0-beta.1');
|
|
|
|
|
expect(im.makeSemver('1.10rc1')).toBe('1.10.0-rc.1');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('converts dot zero versions', async () => {
|
|
|
|
@ -603,12 +636,12 @@ describe('setup-go', () => {
|
|
|
|
|
const toolPath = path.normalize('/cache/go/1.16.1/x64');
|
|
|
|
|
findSpy.mockReturnValue(toolPath);
|
|
|
|
|
dlSpy.mockImplementation(async () => '/some/temp/path');
|
|
|
|
|
exSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
extractTarSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
cacheSpy.mockImplementation(async () => toolPath);
|
|
|
|
|
|
|
|
|
|
await main.run();
|
|
|
|
|
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith('Setup go stable version spec 1.16');
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith('Setup go version spec 1.16');
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith(`Found in cache @ ${toolPath}`);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
@ -625,7 +658,7 @@ describe('setup-go', () => {
|
|
|
|
|
findSpy.mockImplementation(() => '');
|
|
|
|
|
dlSpy.mockImplementation(async () => '/some/temp/path');
|
|
|
|
|
const toolPath = path.normalize('/cache/go/1.17.5/x64');
|
|
|
|
|
exSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
extractTarSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
cacheSpy.mockImplementation(async () => toolPath);
|
|
|
|
|
const expectedUrl =
|
|
|
|
|
'https://github.com/actions/go-versions/releases/download/1.17.6-1668090892/go-1.17.6-darwin-x64.tar.gz';
|
|
|
|
@ -633,7 +666,7 @@ describe('setup-go', () => {
|
|
|
|
|
await main.run();
|
|
|
|
|
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith(
|
|
|
|
|
`Setup go stable version spec ${versionSpec}`
|
|
|
|
|
`Setup go version spec ${versionSpec}`
|
|
|
|
|
);
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith(
|
|
|
|
|
'Attempting to resolve the latest version from the manifest...'
|
|
|
|
@ -666,7 +699,7 @@ describe('setup-go', () => {
|
|
|
|
|
|
|
|
|
|
dlSpy.mockImplementation(async () => '/some/temp/path');
|
|
|
|
|
let toolPath = path.normalize('/cache/go/1.13.7/x64');
|
|
|
|
|
exSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
extractTarSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
cacheSpy.mockImplementation(async () => toolPath);
|
|
|
|
|
|
|
|
|
|
await main.run();
|
|
|
|
@ -674,7 +707,7 @@ describe('setup-go', () => {
|
|
|
|
|
let expPath = path.join(toolPath, 'bin');
|
|
|
|
|
|
|
|
|
|
expect(dlSpy).toHaveBeenCalled();
|
|
|
|
|
expect(exSpy).toHaveBeenCalled();
|
|
|
|
|
expect(extractTarSpy).toHaveBeenCalled();
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith(
|
|
|
|
|
'Attempting to resolve the latest version from the manifest...'
|
|
|
|
|
);
|
|
|
|
@ -708,7 +741,7 @@ describe('setup-go', () => {
|
|
|
|
|
|
|
|
|
|
dlSpy.mockImplementation(async () => '/some/temp/path');
|
|
|
|
|
let toolPath = path.normalize('/cache/go/1.13.7/x64');
|
|
|
|
|
exSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
extractTarSpy.mockImplementation(async () => '/some/other/temp/path');
|
|
|
|
|
cacheSpy.mockImplementation(async () => toolPath);
|
|
|
|
|
|
|
|
|
|
await main.run();
|
|
|
|
@ -719,7 +752,7 @@ describe('setup-go', () => {
|
|
|
|
|
`Failed to resolve version ${versionSpec} from manifest`
|
|
|
|
|
);
|
|
|
|
|
expect(dlSpy).toHaveBeenCalled();
|
|
|
|
|
expect(exSpy).toHaveBeenCalled();
|
|
|
|
|
expect(extractTarSpy).toHaveBeenCalled();
|
|
|
|
|
expect(logSpy).toHaveBeenCalledWith(
|
|
|
|
|
'Attempting to resolve the latest version from the manifest...'
|
|
|
|
|
);
|
|
|
|
|