github-pages-deploy-action/__tests__/git.test.ts

337 lines
8.5 KiB
TypeScript
Raw Normal View History

2020-12-07 23:12:15 +08:00
/* eslint-disable import/first */
// Initial env variable setup for tests.
2020-03-05 21:19:45 +08:00
process.env['INPUT_FOLDER'] = 'build'
process.env['GITHUB_SHA'] = '123'
import {mkdirP, rmRF} from '@actions/io'
import {action, Status, TestFlag} from '../src/constants'
2020-03-05 21:19:45 +08:00
import {execute} from '../src/execute'
import {deploy, init} from '../src/git'
import fs from 'fs'
2020-03-05 21:19:45 +08:00
const originalAction = JSON.stringify(action)
jest.mock('fs', () => ({
existsSync: jest.fn()
}))
2020-03-05 21:19:45 +08:00
jest.mock('@actions/core', () => ({
setFailed: jest.fn(),
2020-03-28 22:35:26 +08:00
getInput: jest.fn(),
isDebug: jest.fn(),
info: jest.fn()
2020-03-05 21:19:45 +08:00
}))
jest.mock('@actions/io', () => ({
rmRF: jest.fn(),
mkdirP: jest.fn()
}))
2020-03-05 21:19:45 +08:00
jest.mock('../src/execute', () => ({
2020-12-07 23:12:15 +08:00
// eslint-disable-next-line @typescript-eslint/naming-convention
2020-10-17 23:47:44 +08:00
__esModule: true,
2020-10-17 23:48:06 +08:00
execute: jest.fn()
2020-03-05 21:19:45 +08:00
}))
2020-03-05 21:19:45 +08:00
describe('git', () => {
afterEach(() => {
2020-03-05 21:19:45 +08:00
Object.assign(action, JSON.parse(originalAction))
})
2020-03-05 21:19:45 +08:00
describe('init', () => {
2020-10-17 23:47:44 +08:00
it('should catch when a function throws an error', async () => {
2020-10-17 23:48:06 +08:00
;(execute as jest.Mock).mockImplementationOnce(() => {
throw new Error('Mocked throw')
})
2020-10-17 23:47:44 +08:00
Object.assign(action, {
silent: false,
repositoryPath: 'JamesIves/github-pages-deploy-action',
token: '123',
2020-10-17 23:47:44 +08:00
branch: 'branch',
folder: '.',
pusher: {
name: 'asd',
email: 'as@cat'
},
isTest: TestFlag.HAS_CHANGED_FILES
2020-10-17 23:47:44 +08:00
})
try {
await init(action)
} catch (error) {
2020-10-17 23:48:06 +08:00
expect(error.message).toBe(
'There was an error initializing the repository: Mocked throw ❌'
)
2020-10-17 23:47:44 +08:00
}
})
2020-03-05 21:19:45 +08:00
})
describe('deploy', () => {
it('should execute commands', async () => {
Object.assign(action, {
2020-06-26 20:18:23 +08:00
silent: false,
folder: 'assets',
2020-03-05 21:19:45 +08:00
branch: 'branch',
token: '123',
pusher: {
2020-03-05 21:19:45 +08:00
name: 'asd',
email: 'as@cat'
},
isTest: TestFlag.HAS_CHANGED_FILES
2020-03-05 21:19:45 +08:00
})
const response = await deploy(action)
2020-10-17 23:47:44 +08:00
// Includes the call to generateWorktree
expect(execute).toBeCalledTimes(11)
expect(rmRF).toBeCalledTimes(1)
expect(response).toBe(Status.SUCCESS)
})
2020-10-17 23:47:44 +08:00
it('should not push when asked to dryRun', async () => {
2020-10-17 23:47:44 +08:00
Object.assign(action, {
silent: false,
dryRun: true,
folder: 'assets',
2020-10-17 23:47:44 +08:00
branch: 'branch',
token: '123',
2020-10-17 23:47:44 +08:00
pusher: {
name: 'asd',
email: 'as@cat'
},
isTest: TestFlag.HAS_CHANGED_FILES
2020-10-17 23:47:44 +08:00
})
const response = await deploy(action)
// Includes the call to generateWorktree
expect(execute).toBeCalledTimes(10)
expect(rmRF).toBeCalledTimes(1)
expect(response).toBe(Status.SUCCESS)
2020-10-17 23:47:44 +08:00
})
it('should execute commands with single commit toggled', async () => {
Object.assign(action, {
2020-06-26 20:18:23 +08:00
silent: false,
folder: 'other',
folderPath: 'other',
2020-03-05 21:19:45 +08:00
branch: 'branch',
token: '123',
singleCommit: true,
pusher: {
name: 'asd',
email: 'as@cat'
},
clean: true,
isTest: TestFlag.HAS_CHANGED_FILES
})
await deploy(action)
// Includes the call to generateWorktree
expect(execute).toBeCalledTimes(10)
expect(rmRF).toBeCalledTimes(1)
})
it('should execute commands with single commit toggled and existing branch', async () => {
Object.assign(action, {
silent: false,
folder: 'other',
folderPath: 'other',
branch: 'branch',
token: '123',
singleCommit: true,
pusher: {
name: 'asd',
email: 'as@cat'
},
clean: true,
isTest: TestFlag.HAS_CHANGED_FILES | TestFlag.HAS_REMOTE_BRANCH
})
await deploy(action)
// Includes the call to generateWorktree
expect(execute).toBeCalledTimes(9)
expect(rmRF).toBeCalledTimes(1)
})
it('should execute commands with single commit and dryRun toggled', async () => {
Object.assign(action, {
2020-06-26 20:18:23 +08:00
silent: false,
2020-10-18 00:23:52 +08:00
folder: 'other',
folderPath: 'other',
branch: 'branch',
gitHubToken: '123',
singleCommit: true,
dryRun: true,
pusher: {
name: 'asd',
email: 'as@cat'
2020-10-18 00:23:52 +08:00
},
clean: true,
isTest: TestFlag.HAS_CHANGED_FILES
})
await deploy(action)
// Includes the call to generateWorktree
expect(execute).toBeCalledTimes(9)
expect(rmRF).toBeCalledTimes(1)
})
2020-10-18 00:23:52 +08:00
it('should not ignore CNAME or nojekyll if they exist in the deployment folder', async () => {
;(fs.existsSync as jest.Mock)
.mockImplementationOnce(() => {
return true
})
.mockImplementationOnce(() => {
return true
})
2020-10-18 00:23:52 +08:00
Object.assign(action, {
silent: false,
folder: 'assets',
folderPath: 'assets',
branch: 'branch',
token: '123',
2020-10-18 00:23:52 +08:00
pusher: {
name: 'asd',
email: 'as@cat'
},
clean: true,
isTest: TestFlag.HAS_CHANGED_FILES
2020-10-18 00:23:52 +08:00
})
const response = await deploy(action)
// Includes the call to generateWorktree
expect(execute).toBeCalledTimes(11)
2020-10-18 00:23:52 +08:00
expect(rmRF).toBeCalledTimes(1)
expect(fs.existsSync).toBeCalledTimes(2)
2020-10-18 00:23:52 +08:00
expect(response).toBe(Status.SUCCESS)
})
describe('with empty GITHUB_SHA', () => {
const oldSha = process.env.GITHUB_SHA
afterAll(() => {
process.env.GITHUB_SHA = oldSha
})
it('should execute commands with clean options', async () => {
process.env.GITHUB_SHA = ''
Object.assign(action, {
silent: false,
folder: 'other',
folderPath: 'other',
branch: 'branch',
token: '123',
pusher: {
name: 'asd',
email: 'as@cat'
},
clean: true,
cleanExclude: '["cat", "montezuma"]',
workspace: 'other',
isTest: TestFlag.NONE
})
await deploy(action)
// Includes the call to generateWorktree
expect(execute).toBeCalledTimes(8)
expect(rmRF).toBeCalledTimes(1)
2020-03-05 21:19:45 +08:00
})
})
2020-03-05 21:19:45 +08:00
it('should execute commands with clean options stored as an array instead', async () => {
Object.assign(action, {
2020-06-26 20:18:23 +08:00
silent: false,
2020-06-06 22:55:49 +08:00
folder: 'assets',
2020-10-18 00:23:52 +08:00
folderPath: 'assets',
2020-03-05 21:19:45 +08:00
branch: 'branch',
token: '123',
pusher: {
2020-03-05 21:19:45 +08:00
name: 'asd',
email: 'as@cat'
},
clean: true,
cleanExclude: ['cat', 'montezuma'],
isTest: TestFlag.NONE
2020-03-05 21:19:45 +08:00
})
2020-03-05 21:19:45 +08:00
await deploy(action)
// Includes the call to generateWorktree
expect(execute).toBeCalledTimes(8)
expect(rmRF).toBeCalledTimes(1)
2020-03-05 21:19:45 +08:00
})
2020-03-05 21:19:45 +08:00
it('should gracefully handle incorrectly formatted clean exclude items', async () => {
Object.assign(action, {
2020-06-26 20:18:23 +08:00
silent: false,
2020-03-05 21:19:45 +08:00
folder: '.',
branch: 'branch',
token: '123',
2020-01-20 05:16:28 +08:00
pusher: {},
clean: true,
2020-03-05 21:19:45 +08:00
targetFolder: 'new_folder',
commitMessage: 'Hello!',
isTest: TestFlag.NONE,
cleanExclude: '["cat, "montezuma"]' // There is a syntax errror in the string.
2020-03-05 21:19:45 +08:00
})
2020-03-05 21:19:45 +08:00
await deploy(action)
expect(execute).toBeCalledTimes(8)
expect(rmRF).toBeCalledTimes(1)
expect(mkdirP).toBeCalledTimes(1)
2020-03-05 21:19:45 +08:00
})
2020-03-05 21:19:45 +08:00
it('should stop early if there is nothing to commit', async () => {
Object.assign(action, {
2020-06-26 20:18:23 +08:00
silent: false,
2020-06-06 22:55:49 +08:00
folder: 'assets',
2020-03-05 21:19:45 +08:00
branch: 'branch',
token: '123',
pusher: {
2020-03-05 21:19:45 +08:00
name: 'asd',
email: 'as@cat'
},
isTest: TestFlag.NONE // Setting this flag to None means there will never be anything to commit and the action will exit early.
2020-03-05 21:19:45 +08:00
})
2020-05-15 05:56:56 +08:00
const response = await deploy(action)
expect(execute).toBeCalledTimes(8)
expect(rmRF).toBeCalledTimes(1)
2020-05-15 05:56:56 +08:00
expect(response).toBe(Status.SKIPPED)
2020-03-05 21:19:45 +08:00
})
2020-10-17 23:47:44 +08:00
it('should catch when a function throws an error', async () => {
2020-10-17 23:48:06 +08:00
;(execute as jest.Mock).mockImplementationOnce(() => {
throw new Error('Mocked throw')
})
2020-10-17 23:47:44 +08:00
Object.assign(action, {
silent: false,
folder: 'assets',
branch: 'branch',
token: '123',
2020-10-17 23:47:44 +08:00
pusher: {
name: 'asd',
email: 'as@cat'
},
isTest: TestFlag.HAS_CHANGED_FILES
2020-10-17 23:47:44 +08:00
})
try {
await deploy(action)
} catch (error) {
2020-10-17 23:48:06 +08:00
expect(error.message).toBe(
'The deploy step encountered an error: Mocked throw ❌'
)
2020-10-17 23:47:44 +08:00
}
})
2020-03-05 21:19:45 +08:00
})
})