2023-03-09 14:49:35 +02:00
|
|
|
import * as path from 'path';
|
|
|
|
|
import * as io from '@actions/io';
|
|
|
|
|
import * as exec from '@actions/exec';
|
2026-06-29 13:19:49 +01:00
|
|
|
import * as tc from '@actions/tool-cache';
|
2023-03-09 14:49:35 +02:00
|
|
|
import * as gpg from '../src/gpg';
|
2020-05-02 04:33:15 -07:00
|
|
|
|
|
|
|
|
jest.mock('@actions/exec', () => {
|
|
|
|
|
return {
|
|
|
|
|
exec: jest.fn()
|
|
|
|
|
};
|
|
|
|
|
});
|
|
|
|
|
|
2026-06-29 13:19:49 +01:00
|
|
|
jest.mock('@actions/tool-cache', () => {
|
|
|
|
|
return {
|
|
|
|
|
downloadTool: jest.fn()
|
|
|
|
|
};
|
|
|
|
|
});
|
|
|
|
|
|
2020-05-02 04:33:15 -07:00
|
|
|
const tempDir = path.join(__dirname, 'runner', 'temp');
|
|
|
|
|
process.env['RUNNER_TEMP'] = tempDir;
|
|
|
|
|
|
|
|
|
|
describe('gpg tests', () => {
|
|
|
|
|
beforeEach(async () => {
|
|
|
|
|
await io.mkdirP(tempDir);
|
2020-07-15 19:53:39 -06:00
|
|
|
});
|
2020-05-02 04:33:15 -07:00
|
|
|
|
|
|
|
|
afterAll(async () => {
|
|
|
|
|
try {
|
|
|
|
|
await io.rmRF(tempDir);
|
|
|
|
|
} catch {
|
|
|
|
|
console.log('Failed to remove test directories');
|
|
|
|
|
}
|
2020-07-16 19:12:25 -06:00
|
|
|
});
|
2020-05-02 04:33:15 -07:00
|
|
|
|
2026-06-29 13:19:49 +01:00
|
|
|
describe('toGpgPath', () => {
|
|
|
|
|
const originalPlatform = process.platform;
|
|
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
|
Object.defineProperty(process, 'platform', {value: originalPlatform});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('returns path unchanged on non-Windows platforms', () => {
|
|
|
|
|
Object.defineProperty(process, 'platform', {value: 'linux'});
|
|
|
|
|
expect(gpg.toGpgPath('/tmp/some/path')).toBe('/tmp/some/path');
|
|
|
|
|
expect(gpg.toGpgPath('D:\\a\\_temp\\file')).toBe('D:\\a\\_temp\\file');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('converts Windows backslashes and drive letter to POSIX path on Windows', () => {
|
|
|
|
|
Object.defineProperty(process, 'platform', {value: 'win32'});
|
|
|
|
|
expect(gpg.toGpgPath('D:\\a\\_temp\\gpg-home')).toBe(
|
|
|
|
|
'/d/a/_temp/gpg-home'
|
|
|
|
|
);
|
|
|
|
|
expect(
|
|
|
|
|
gpg.toGpgPath('C:\\Users\\runner\\AppData\\Local\\Temp\\key.asc')
|
|
|
|
|
).toBe('/c/Users/runner/AppData/Local/Temp/key.asc');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
it('handles uppercase and lowercase drive letters on Windows', () => {
|
|
|
|
|
Object.defineProperty(process, 'platform', {value: 'win32'});
|
|
|
|
|
expect(gpg.toGpgPath('d:\\a\\_temp\\file')).toBe('/d/a/_temp/file');
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
2020-05-02 04:33:15 -07:00
|
|
|
describe('importKey', () => {
|
|
|
|
|
it('attempts to import private key and returns null key id on failure', async () => {
|
|
|
|
|
const privateKey = 'KEY CONTENTS';
|
|
|
|
|
const keyId = await gpg.importKey(privateKey);
|
|
|
|
|
|
|
|
|
|
expect(keyId).toBeNull();
|
|
|
|
|
|
2023-03-09 14:49:35 +02:00
|
|
|
expect(exec.exec).toHaveBeenCalledWith(
|
|
|
|
|
'gpg',
|
|
|
|
|
expect.anything(),
|
|
|
|
|
expect.anything()
|
|
|
|
|
);
|
2020-05-02 04:33:15 -07:00
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
describe('deleteKey', () => {
|
|
|
|
|
it('deletes private key', async () => {
|
|
|
|
|
const keyId = 'asdfhjkl';
|
|
|
|
|
await gpg.deleteKey(keyId);
|
|
|
|
|
|
2023-03-09 14:49:35 +02:00
|
|
|
expect(exec.exec).toHaveBeenCalledWith(
|
|
|
|
|
'gpg',
|
|
|
|
|
expect.anything(),
|
|
|
|
|
expect.anything()
|
|
|
|
|
);
|
2020-05-02 04:33:15 -07:00
|
|
|
});
|
2026-06-29 13:19:49 +01:00
|
|
|
|
|
|
|
|
describe('verifyPackageSignature', () => {
|
|
|
|
|
it('imports bundled key and verifies package', async () => {
|
|
|
|
|
const publicKeyContent =
|
|
|
|
|
'-----BEGIN PGP PUBLIC KEY BLOCK-----\ntest\n-----END PGP PUBLIC KEY BLOCK-----';
|
|
|
|
|
(tc.downloadTool as jest.Mock).mockResolvedValue('/tmp/jdk.tar.gz.sig');
|
|
|
|
|
await gpg.verifyPackageSignature(
|
|
|
|
|
'/tmp/jdk.tar.gz',
|
|
|
|
|
'https://example.com/jdk.tar.gz.sig',
|
|
|
|
|
publicKeyContent
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
expect(tc.downloadTool).toHaveBeenCalledWith(
|
|
|
|
|
'https://example.com/jdk.tar.gz.sig'
|
|
|
|
|
);
|
|
|
|
|
expect(exec.exec).toHaveBeenNthCalledWith(
|
|
|
|
|
1,
|
|
|
|
|
'gpg',
|
|
|
|
|
[
|
|
|
|
|
'--homedir',
|
|
|
|
|
expect.any(String),
|
|
|
|
|
'--batch',
|
|
|
|
|
'--import',
|
|
|
|
|
expect.stringContaining('public-key.asc')
|
|
|
|
|
],
|
|
|
|
|
expect.objectContaining({silent: true})
|
|
|
|
|
);
|
|
|
|
|
expect(exec.exec).toHaveBeenNthCalledWith(
|
|
|
|
|
2,
|
|
|
|
|
'gpg',
|
|
|
|
|
[
|
|
|
|
|
'--homedir',
|
|
|
|
|
expect.any(String),
|
|
|
|
|
'--batch',
|
|
|
|
|
'--verify',
|
|
|
|
|
'/tmp/jdk.tar.gz.sig',
|
|
|
|
|
'/tmp/jdk.tar.gz'
|
|
|
|
|
],
|
|
|
|
|
expect.objectContaining({silent: true})
|
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
});
|
2020-05-02 04:33:15 -07:00
|
|
|
});
|
|
|
|
|
});
|