123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- import * as assert from 'assert'
- import * as core from '@actions/core'
- import * as fsHelper from '../lib/fs-helper'
- import * as github from '@actions/github'
- import * as inputHelper from '../lib/input-helper'
- import * as path from 'path'
- import {ISourceSettings} from '../lib/git-source-provider'
- const originalGitHubWorkspace = process.env['GITHUB_WORKSPACE']
- const gitHubWorkspace = path.resolve('/checkout-tests/workspace')
- // Inputs for mock @actions/core
- let inputs = {} as any
- // Shallow clone original @actions/github context
- let originalContext = {...github.context}
- describe('input-helper tests', () => {
- beforeAll(() => {
- // Mock @actions/core getInput()
- jest.spyOn(core, 'getInput').mockImplementation((name: string) => {
- return inputs[name]
- })
- // Mock @actions/github context
- jest.spyOn(github.context, 'repo', 'get').mockImplementation(() => {
- return {
- owner: 'some-owner',
- repo: 'some-repo'
- }
- })
- github.context.ref = 'refs/heads/some-ref'
- github.context.sha = '1234567890123456789012345678901234567890'
- // Mock ./fs-helper directoryExistsSync()
- jest
- .spyOn(fsHelper, 'directoryExistsSync')
- .mockImplementation((path: string) => path == gitHubWorkspace)
- // GitHub workspace
- process.env['GITHUB_WORKSPACE'] = gitHubWorkspace
- })
- beforeEach(() => {
- // Reset inputs
- inputs = {}
- })
- afterAll(() => {
- // Restore GitHub workspace
- delete process.env['GITHUB_WORKSPACE']
- if (originalGitHubWorkspace) {
- process.env['GITHUB_WORKSPACE'] = originalGitHubWorkspace
- }
- // Restore @actions/github context
- github.context.ref = originalContext.ref
- github.context.sha = originalContext.sha
- // Restore
- jest.restoreAllMocks()
- })
- it('sets defaults', () => {
- const settings: ISourceSettings = inputHelper.getInputs()
- expect(settings).toBeTruthy()
- expect(settings.authToken).toBeFalsy()
- expect(settings.clean).toBe(true)
- expect(settings.commit).toBeTruthy()
- expect(settings.commit).toBe('1234567890123456789012345678901234567890')
- expect(settings.fetchDepth).toBe(1)
- expect(settings.lfs).toBe(false)
- expect(settings.ref).toBe('refs/heads/some-ref')
- expect(settings.repositoryName).toBe('some-repo')
- expect(settings.repositoryOwner).toBe('some-owner')
- expect(settings.repositoryPath).toBe(gitHubWorkspace)
- })
- it('qualifies ref', () => {
- let originalRef = github.context.ref
- try {
- github.context.ref = 'some-unqualified-ref'
- const settings: ISourceSettings = inputHelper.getInputs()
- expect(settings).toBeTruthy()
- expect(settings.commit).toBe('1234567890123456789012345678901234567890')
- expect(settings.ref).toBe('refs/heads/some-unqualified-ref')
- } finally {
- github.context.ref = originalRef
- }
- })
- it('requires qualified repo', () => {
- inputs.repository = 'some-unqualified-repo'
- assert.throws(() => {
- inputHelper.getInputs()
- }, /Invalid repository 'some-unqualified-repo'/)
- })
- it('roots path', () => {
- inputs.path = 'some-directory/some-subdirectory'
- const settings: ISourceSettings = inputHelper.getInputs()
- expect(settings.repositoryPath).toBe(
- path.join(gitHubWorkspace, 'some-directory', 'some-subdirectory')
- )
- })
- it('sets correct default ref/sha for other repo', () => {
- inputs.repository = 'some-owner/some-other-repo'
- const settings: ISourceSettings = inputHelper.getInputs()
- expect(settings.ref).toBe('refs/heads/master')
- expect(settings.commit).toBeFalsy()
- })
- it('sets ref to empty when explicit sha', () => {
- inputs.ref = '1111111111222222222233333333334444444444'
- const settings: ISourceSettings = inputHelper.getInputs()
- expect(settings.ref).toBeFalsy()
- expect(settings.commit).toBe('1111111111222222222233333333334444444444')
- })
- it('sets sha to empty when explicit ref', () => {
- inputs.ref = 'refs/heads/some-other-ref'
- const settings: ISourceSettings = inputHelper.getInputs()
- expect(settings.ref).toBe('refs/heads/some-other-ref')
- expect(settings.commit).toBeFalsy()
- })
- it('gives good error message for submodules input', () => {
- inputs.submodules = 'true'
- assert.throws(() => {
- inputHelper.getInputs()
- }, /The input 'submodules' is not supported/)
- })
- })
|