123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- import * as assert from 'assert'
- 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')
- // Late bind
- let inputHelper: any
- // Mock @actions/core
- let inputs = {} as any
- const mockCore = jest.genMockFromModule('@actions/core') as any
- mockCore.getInput = (name: string) => {
- return inputs[name]
- }
- // Mock @actions/github
- const mockGitHub = jest.genMockFromModule('@actions/github') as any
- mockGitHub.context = {
- repo: {
- owner: 'some-owner',
- repo: 'some-repo'
- },
- ref: 'refs/heads/some-ref',
- sha: '1234567890123456789012345678901234567890'
- }
- // Mock ./fs-helper
- const mockFSHelper = jest.genMockFromModule('../lib/fs-helper') as any
- mockFSHelper.directoryExistsSync = (path: string) => path == gitHubWorkspace
- describe('input-helper tests', () => {
- beforeAll(() => {
- // GitHub workspace
- process.env['GITHUB_WORKSPACE'] = gitHubWorkspace
- // Mocks
- jest.setMock('@actions/core', mockCore)
- jest.setMock('@actions/github', mockGitHub)
- jest.setMock('../lib/fs-helper', mockFSHelper)
- // Now import
- inputHelper = require('../lib/input-helper')
- })
- beforeEach(() => {
- // Reset inputs
- inputs = {}
- })
- afterAll(() => {
- // Reset GitHub workspace
- delete process.env['GITHUB_WORKSPACE']
- if (originalGitHubWorkspace) {
- process.env['GITHUB_WORKSPACE'] = originalGitHubWorkspace
- }
- // Reset modules
- jest.resetModules()
- })
- it('sets defaults', () => {
- const settings: ISourceSettings = inputHelper.getInputs()
- expect(settings).toBeTruthy()
- expect(settings.accessToken).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('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/)
- })
- })
|