2021-02-05 01:50:35 +08:00
|
|
|
import {exportVariable} from '@actions/core'
|
2021-01-21 22:08:31 +08:00
|
|
|
import {mkdirP} from '@actions/io'
|
2021-02-05 01:50:35 +08:00
|
|
|
import child_process, {execFileSync, execSync} from 'child_process'
|
2021-01-21 22:08:31 +08:00
|
|
|
import {appendFileSync} from 'fs'
|
|
|
|
import {action, TestFlag} from '../src/constants'
|
|
|
|
import {execute} from '../src/execute'
|
|
|
|
import {configureSSH} from '../src/ssh'
|
|
|
|
|
|
|
|
const originalAction = JSON.stringify(action)
|
|
|
|
|
|
|
|
jest.mock('fs', () => ({
|
|
|
|
appendFileSync: jest.fn(),
|
|
|
|
existsSync: jest.fn()
|
|
|
|
}))
|
|
|
|
|
2021-02-05 01:50:35 +08:00
|
|
|
jest.mock('child_process', () => ({
|
|
|
|
execFileSync: jest.fn(),
|
|
|
|
execSync: jest.fn()
|
|
|
|
}))
|
|
|
|
|
2021-01-21 22:08:31 +08:00
|
|
|
jest.mock('@actions/io', () => ({
|
|
|
|
rmRF: jest.fn(),
|
|
|
|
mkdirP: jest.fn()
|
|
|
|
}))
|
|
|
|
|
|
|
|
jest.mock('@actions/core', () => ({
|
|
|
|
setFailed: jest.fn(),
|
|
|
|
getInput: jest.fn(),
|
|
|
|
setOutput: jest.fn(),
|
|
|
|
isDebug: jest.fn(),
|
2021-02-05 01:50:35 +08:00
|
|
|
info: jest.fn(),
|
|
|
|
exportVariable: jest.fn()
|
2021-01-21 22:08:31 +08:00
|
|
|
}))
|
|
|
|
|
|
|
|
jest.mock('../src/execute', () => ({
|
|
|
|
execute: jest.fn()
|
|
|
|
}))
|
|
|
|
|
|
|
|
describe('configureSSH', () => {
|
|
|
|
afterEach(() => {
|
|
|
|
Object.assign(action, JSON.parse(originalAction))
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should skip client configuration if sshKey is set to true', async () => {
|
|
|
|
Object.assign(action, {
|
|
|
|
silent: false,
|
|
|
|
folder: 'assets',
|
|
|
|
branch: 'branch',
|
|
|
|
sshKey: true,
|
|
|
|
pusher: {
|
|
|
|
name: 'asd',
|
|
|
|
email: 'as@cat'
|
|
|
|
},
|
|
|
|
isTest: TestFlag.HAS_CHANGED_FILES
|
|
|
|
})
|
|
|
|
|
|
|
|
await configureSSH(action)
|
|
|
|
|
|
|
|
expect(execute).toBeCalledTimes(0)
|
|
|
|
expect(mkdirP).toBeCalledTimes(0)
|
|
|
|
expect(appendFileSync).toBeCalledTimes(0)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should configure the ssh client if a key is defined', async () => {
|
2021-02-05 01:50:35 +08:00
|
|
|
;(child_process.execFileSync as jest.Mock).mockImplementationOnce(() => {
|
|
|
|
return 'SSH_AUTH_SOCK=/some/random/folder/agent.123; export SSH_AUTH_SOCK;\nSSH_AGENT_PID=123; export SSH_AGENT_PID;'
|
|
|
|
})
|
|
|
|
|
|
|
|
Object.assign(action, {
|
|
|
|
silent: false,
|
|
|
|
folder: 'assets',
|
|
|
|
branch: 'branch',
|
|
|
|
sshKey: '?=-----BEGIN 123 456\n 789',
|
|
|
|
pusher: {
|
|
|
|
name: 'asd',
|
|
|
|
email: 'as@cat'
|
|
|
|
},
|
|
|
|
isTest: TestFlag.HAS_CHANGED_FILES
|
|
|
|
})
|
|
|
|
|
|
|
|
await configureSSH(action)
|
|
|
|
|
|
|
|
expect(execFileSync).toBeCalledTimes(1)
|
|
|
|
expect(exportVariable).toBeCalledTimes(2)
|
|
|
|
expect(execSync).toBeCalledTimes(3)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should not export variables if the return from ssh-agent is skewed', async () => {
|
|
|
|
;(child_process.execFileSync as jest.Mock).mockImplementationOnce(() => {
|
|
|
|
return 'useless nonsense here;'
|
|
|
|
})
|
|
|
|
|
2021-01-21 22:08:31 +08:00
|
|
|
Object.assign(action, {
|
|
|
|
silent: false,
|
|
|
|
folder: 'assets',
|
|
|
|
branch: 'branch',
|
|
|
|
sshKey: '?=-----BEGIN 123 456\n 789',
|
|
|
|
pusher: {
|
|
|
|
name: 'asd',
|
|
|
|
email: 'as@cat'
|
|
|
|
},
|
|
|
|
isTest: TestFlag.HAS_CHANGED_FILES
|
|
|
|
})
|
|
|
|
|
|
|
|
await configureSSH(action)
|
|
|
|
|
2021-02-05 01:50:35 +08:00
|
|
|
expect(execFileSync).toBeCalledTimes(1)
|
|
|
|
expect(exportVariable).toBeCalledTimes(0)
|
|
|
|
expect(execSync).toBeCalledTimes(3)
|
2021-01-21 22:08:31 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
it('should throw if something errors', async () => {
|
2021-02-05 01:50:35 +08:00
|
|
|
;(child_process.execFileSync as jest.Mock).mockImplementationOnce(() => {
|
2021-01-21 22:08:31 +08:00
|
|
|
throw new Error('Mocked throw')
|
|
|
|
})
|
|
|
|
|
|
|
|
Object.assign(action, {
|
|
|
|
silent: false,
|
|
|
|
folder: 'assets',
|
|
|
|
branch: 'branch',
|
|
|
|
sshKey: 'real_key',
|
|
|
|
pusher: {
|
|
|
|
name: 'asd',
|
|
|
|
email: 'as@cat'
|
|
|
|
},
|
|
|
|
isTest: TestFlag.HAS_CHANGED_FILES
|
|
|
|
})
|
|
|
|
|
|
|
|
try {
|
|
|
|
await configureSSH(action)
|
|
|
|
} catch (error) {
|
|
|
|
expect(error.message).toBe(
|
|
|
|
'The ssh client configuration encountered an error: Mocked throw ❌'
|
|
|
|
)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|