mirror of
https://github.com/JamesIves/github-pages-deploy-action.git
synced 2023-12-15 20:03:39 +08:00
7a94841600
* Token simplification * Access Token / Github Token -> Token * Oops * Typos * Update README.md * Update README.md * Update action.yml Co-authored-by: Axel Hecht <axel@pike.org> * Update README.md Co-authored-by: Axel Hecht <axel@pike.org> * Update README.md Co-authored-by: Axel Hecht <axel@pike.org>
322 lines
7.9 KiB
TypeScript
322 lines
7.9 KiB
TypeScript
/* eslint-disable import/first */
|
|
// Initial env variable setup for tests.
|
|
process.env['INPUT_FOLDER'] = 'build'
|
|
process.env['GITHUB_SHA'] = '123'
|
|
|
|
import {mkdirP, rmRF} from '@actions/io'
|
|
import {action, Status} from '../src/constants'
|
|
import {execute} from '../src/execute'
|
|
import {deploy, generateBranch, init} from '../src/git'
|
|
import fs from 'fs'
|
|
|
|
const originalAction = JSON.stringify(action)
|
|
|
|
jest.mock('@actions/core', () => ({
|
|
setFailed: jest.fn(),
|
|
getInput: jest.fn(),
|
|
isDebug: jest.fn(),
|
|
info: jest.fn()
|
|
}))
|
|
|
|
jest.mock('@actions/io', () => ({
|
|
rmRF: jest.fn(),
|
|
mkdirP: jest.fn()
|
|
}))
|
|
|
|
jest.mock('../src/execute', () => ({
|
|
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
__esModule: true,
|
|
execute: jest.fn()
|
|
}))
|
|
|
|
describe('git', () => {
|
|
afterEach(() => {
|
|
Object.assign(action, JSON.parse(originalAction))
|
|
})
|
|
|
|
describe('init', () => {
|
|
it('should catch when a function throws an error', async () => {
|
|
;(execute as jest.Mock).mockImplementationOnce(() => {
|
|
throw new Error('Mocked throw')
|
|
})
|
|
|
|
Object.assign(action, {
|
|
silent: false,
|
|
repositoryPath: 'JamesIves/github-pages-deploy-action',
|
|
token: '123',
|
|
branch: 'branch',
|
|
folder: '.',
|
|
isTest: true,
|
|
pusher: {
|
|
name: 'asd',
|
|
email: 'as@cat'
|
|
}
|
|
})
|
|
|
|
try {
|
|
await init(action)
|
|
} catch (error) {
|
|
expect(error.message).toBe(
|
|
'There was an error initializing the repository: Mocked throw ❌'
|
|
)
|
|
}
|
|
})
|
|
})
|
|
|
|
describe('generateBranch', () => {
|
|
it('should execute five commands', async () => {
|
|
Object.assign(action, {
|
|
silent: false,
|
|
token: '123',
|
|
branch: 'branch',
|
|
folder: '.',
|
|
pusher: {
|
|
name: 'asd',
|
|
email: 'as@cat'
|
|
}
|
|
})
|
|
|
|
await generateBranch(action)
|
|
expect(execute).toBeCalledTimes(5)
|
|
})
|
|
|
|
it('should catch when a function throws an error', async () => {
|
|
;(execute as jest.Mock).mockImplementationOnce(() => {
|
|
throw new Error('Mocked throw')
|
|
})
|
|
|
|
Object.assign(action, {
|
|
silent: false,
|
|
token: '123',
|
|
branch: 'branch',
|
|
folder: '.',
|
|
pusher: {
|
|
name: 'asd',
|
|
email: 'as@cat'
|
|
}
|
|
})
|
|
|
|
try {
|
|
await generateBranch(action)
|
|
} catch (error) {
|
|
expect(error.message).toBe(
|
|
'There was an error creating the deployment branch: Mocked throw ❌'
|
|
)
|
|
}
|
|
})
|
|
})
|
|
|
|
describe('deploy', () => {
|
|
it('should execute commands', async () => {
|
|
Object.assign(action, {
|
|
silent: false,
|
|
folder: 'assets',
|
|
branch: 'branch',
|
|
token: '123',
|
|
pusher: {
|
|
name: 'asd',
|
|
email: 'as@cat'
|
|
}
|
|
})
|
|
|
|
const response = await deploy(action)
|
|
|
|
// Includes the call to generateBranch
|
|
expect(execute).toBeCalledTimes(10)
|
|
expect(execute).toHaveBeenNthCalledWith(
|
|
9,
|
|
expect.not.stringContaining('--dry-run'),
|
|
expect.anything(),
|
|
false
|
|
)
|
|
expect(rmRF).toBeCalledTimes(1)
|
|
expect(response).toBe(Status.SUCCESS)
|
|
})
|
|
|
|
it('should push with --dry-run', async () => {
|
|
Object.assign(action, {
|
|
silent: false,
|
|
dryRun: true,
|
|
folder: 'assets',
|
|
branch: 'branch',
|
|
token: '123',
|
|
pusher: {
|
|
name: 'asd',
|
|
email: 'as@cat'
|
|
}
|
|
})
|
|
|
|
const response = await deploy(action)
|
|
|
|
// Includes the call to generateBranch
|
|
expect(execute).toBeCalledTimes(10)
|
|
expect(execute).toHaveBeenNthCalledWith(
|
|
9,
|
|
expect.stringContaining('--dry-run'),
|
|
expect.anything(),
|
|
false
|
|
)
|
|
expect(rmRF).toBeCalledTimes(1)
|
|
expect(response).toBe(Status.SUCCESS)
|
|
})
|
|
|
|
it('should execute commands with single commit toggled', async () => {
|
|
Object.assign(action, {
|
|
silent: false,
|
|
folder: 'other',
|
|
folderPath: 'other',
|
|
branch: 'branch',
|
|
token: '123',
|
|
singleCommit: true,
|
|
pusher: {
|
|
name: 'asd',
|
|
email: 'as@cat'
|
|
},
|
|
clean: true
|
|
})
|
|
|
|
await deploy(action)
|
|
|
|
// Includes the call to generateBranch
|
|
expect(execute).toBeCalledTimes(16)
|
|
expect(rmRF).toBeCalledTimes(1)
|
|
})
|
|
|
|
it('should not ignore CNAME or nojekyll if they exist in the deployment folder', async () => {
|
|
Object.assign(action, {
|
|
silent: false,
|
|
folder: 'assets',
|
|
folderPath: 'assets',
|
|
branch: 'branch',
|
|
token: '123',
|
|
pusher: {
|
|
name: 'asd',
|
|
email: 'as@cat'
|
|
},
|
|
clean: true
|
|
})
|
|
|
|
fs.createWriteStream('assets/.nojekyll')
|
|
fs.createWriteStream('assets/CNAME')
|
|
|
|
const response = await deploy(action)
|
|
|
|
// Includes the call to generateBranch
|
|
expect(execute).toBeCalledTimes(10)
|
|
expect(rmRF).toBeCalledTimes(1)
|
|
expect(response).toBe(Status.SUCCESS)
|
|
})
|
|
|
|
it('should execute commands with clean options, ommits sha commit message', 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'
|
|
})
|
|
|
|
await deploy(action)
|
|
|
|
// Includes the call to generateBranch
|
|
expect(execute).toBeCalledTimes(10)
|
|
expect(rmRF).toBeCalledTimes(1)
|
|
})
|
|
|
|
it('should execute commands with clean options stored as an array instead', async () => {
|
|
Object.assign(action, {
|
|
silent: false,
|
|
folder: 'assets',
|
|
folderPath: 'assets',
|
|
branch: 'branch',
|
|
token: '123',
|
|
pusher: {
|
|
name: 'asd',
|
|
email: 'as@cat'
|
|
},
|
|
clean: true,
|
|
cleanExclude: ['cat', 'montezuma']
|
|
})
|
|
|
|
await deploy(action)
|
|
|
|
// Includes the call to generateBranch
|
|
expect(execute).toBeCalledTimes(10)
|
|
expect(rmRF).toBeCalledTimes(1)
|
|
})
|
|
|
|
it('should gracefully handle incorrectly formatted clean exclude items', async () => {
|
|
Object.assign(action, {
|
|
silent: false,
|
|
folder: '.',
|
|
branch: 'branch',
|
|
token: '123',
|
|
pusher: {},
|
|
clean: true,
|
|
targetFolder: 'new_folder',
|
|
commitMessage: 'Hello!',
|
|
isTest: true,
|
|
cleanExclude: '["cat, "montezuma"]' // There is a syntax errror in the string.
|
|
})
|
|
|
|
await deploy(action)
|
|
|
|
expect(execute).toBeCalledTimes(10)
|
|
expect(rmRF).toBeCalledTimes(1)
|
|
expect(mkdirP).toBeCalledTimes(1)
|
|
})
|
|
|
|
it('should stop early if there is nothing to commit', async () => {
|
|
Object.assign(action, {
|
|
silent: false,
|
|
folder: 'assets',
|
|
branch: 'branch',
|
|
token: '123',
|
|
pusher: {
|
|
name: 'asd',
|
|
email: 'as@cat'
|
|
},
|
|
isTest: false // Setting this env variable to false means there will never be anything to commit and the action will exit early.
|
|
})
|
|
|
|
const response = await deploy(action)
|
|
expect(execute).toBeCalledTimes(10)
|
|
expect(rmRF).toBeCalledTimes(1)
|
|
expect(response).toBe(Status.SKIPPED)
|
|
})
|
|
|
|
it('should catch when a function throws an error', async () => {
|
|
;(execute as jest.Mock).mockImplementationOnce(() => {
|
|
throw new Error('Mocked throw')
|
|
})
|
|
|
|
Object.assign(action, {
|
|
silent: false,
|
|
folder: 'assets',
|
|
branch: 'branch',
|
|
token: '123',
|
|
pusher: {
|
|
name: 'asd',
|
|
email: 'as@cat'
|
|
}
|
|
})
|
|
|
|
try {
|
|
await deploy(action)
|
|
} catch (error) {
|
|
expect(error.message).toBe(
|
|
'The deploy step encountered an error: Mocked throw ❌'
|
|
)
|
|
}
|
|
})
|
|
})
|
|
})
|