123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168 |
- import * as assert from 'assert'
- import * as refHelper from '../lib/ref-helper'
- import {IGitCommandManager} from '../lib/git-command-manager'
- const commit = '1234567890123456789012345678901234567890'
- let git: IGitCommandManager
- describe('ref-helper tests', () => {
- beforeEach(() => {
- git = ({} as unknown) as IGitCommandManager
- })
- it('getCheckoutInfo requires git', async () => {
- const git = (null as unknown) as IGitCommandManager
- try {
- await refHelper.getCheckoutInfo(git, 'refs/heads/my/branch', commit)
- throw new Error('Should not reach here')
- } catch (err) {
- expect(err.message).toBe('Arg git cannot be empty')
- }
- })
- it('getCheckoutInfo requires ref or commit', async () => {
- try {
- await refHelper.getCheckoutInfo(git, '', '')
- throw new Error('Should not reach here')
- } catch (err) {
- expect(err.message).toBe('Args ref and commit cannot both be empty')
- }
- })
- it('getCheckoutInfo sha only', async () => {
- const checkoutInfo = await refHelper.getCheckoutInfo(git, '', commit)
- expect(checkoutInfo.ref).toBe(commit)
- expect(checkoutInfo.startPoint).toBeFalsy()
- })
- it('getCheckoutInfo refs/heads/', async () => {
- const checkoutInfo = await refHelper.getCheckoutInfo(
- git,
- 'refs/heads/my/branch',
- commit
- )
- expect(checkoutInfo.ref).toBe('my/branch')
- expect(checkoutInfo.startPoint).toBe('refs/remotes/origin/my/branch')
- })
- it('getCheckoutInfo refs/pull/', async () => {
- const checkoutInfo = await refHelper.getCheckoutInfo(
- git,
- 'refs/pull/123/merge',
- commit
- )
- expect(checkoutInfo.ref).toBe('refs/remotes/pull/123/merge')
- expect(checkoutInfo.startPoint).toBeFalsy()
- })
- it('getCheckoutInfo refs/tags/', async () => {
- const checkoutInfo = await refHelper.getCheckoutInfo(
- git,
- 'refs/tags/my-tag',
- commit
- )
- expect(checkoutInfo.ref).toBe('refs/tags/my-tag')
- expect(checkoutInfo.startPoint).toBeFalsy()
- })
- it('getCheckoutInfo unqualified branch only', async () => {
- git.branchExists = jest.fn(async (remote: boolean, pattern: string) => {
- return true
- })
- const checkoutInfo = await refHelper.getCheckoutInfo(git, 'my/branch', '')
- expect(checkoutInfo.ref).toBe('my/branch')
- expect(checkoutInfo.startPoint).toBe('refs/remotes/origin/my/branch')
- })
- it('getCheckoutInfo unqualified tag only', async () => {
- git.branchExists = jest.fn(async (remote: boolean, pattern: string) => {
- return false
- })
- git.tagExists = jest.fn(async (pattern: string) => {
- return true
- })
- const checkoutInfo = await refHelper.getCheckoutInfo(git, 'my-tag', '')
- expect(checkoutInfo.ref).toBe('refs/tags/my-tag')
- expect(checkoutInfo.startPoint).toBeFalsy()
- })
- it('getCheckoutInfo unqualified ref only, not a branch or tag', async () => {
- git.branchExists = jest.fn(async (remote: boolean, pattern: string) => {
- return false
- })
- git.tagExists = jest.fn(async (pattern: string) => {
- return false
- })
- try {
- await refHelper.getCheckoutInfo(git, 'my-ref', '')
- throw new Error('Should not reach here')
- } catch (err) {
- expect(err.message).toBe(
- "A branch or tag with the name 'my-ref' could not be found"
- )
- }
- })
- it('getRefSpec requires ref or commit', async () => {
- assert.throws(
- () => refHelper.getRefSpec('', ''),
- /Args ref and commit cannot both be empty/
- )
- })
- it('getRefSpec sha + refs/heads/', async () => {
- const refSpec = refHelper.getRefSpec('refs/heads/my/branch', commit)
- expect(refSpec.length).toBe(1)
- expect(refSpec[0]).toBe(`+${commit}:refs/remotes/origin/my/branch`)
- })
- it('getRefSpec sha + refs/pull/', async () => {
- const refSpec = refHelper.getRefSpec('refs/pull/123/merge', commit)
- expect(refSpec.length).toBe(1)
- expect(refSpec[0]).toBe(`+${commit}:refs/remotes/pull/123/merge`)
- })
- it('getRefSpec sha + refs/tags/', async () => {
- const refSpec = refHelper.getRefSpec('refs/tags/my-tag', commit)
- expect(refSpec.length).toBe(1)
- expect(refSpec[0]).toBe(`+${commit}:refs/tags/my-tag`)
- })
- it('getRefSpec sha only', async () => {
- const refSpec = refHelper.getRefSpec('', commit)
- expect(refSpec.length).toBe(1)
- expect(refSpec[0]).toBe(commit)
- })
- it('getRefSpec unqualified ref only', async () => {
- const refSpec = refHelper.getRefSpec('my-ref', '')
- expect(refSpec.length).toBe(2)
- expect(refSpec[0]).toBe('+refs/heads/my-ref*:refs/remotes/origin/my-ref*')
- expect(refSpec[1]).toBe('+refs/tags/my-ref*:refs/tags/my-ref*')
- })
- it('getRefSpec refs/heads/ only', async () => {
- const refSpec = refHelper.getRefSpec('refs/heads/my/branch', '')
- expect(refSpec.length).toBe(1)
- expect(refSpec[0]).toBe(
- '+refs/heads/my/branch:refs/remotes/origin/my/branch'
- )
- })
- it('getRefSpec refs/pull/ only', async () => {
- const refSpec = refHelper.getRefSpec('refs/pull/123/merge', '')
- expect(refSpec.length).toBe(1)
- expect(refSpec[0]).toBe('+refs/pull/123/merge:refs/remotes/pull/123/merge')
- })
- it('getRefSpec refs/tags/ only', async () => {
- const refSpec = refHelper.getRefSpec('refs/tags/my-tag', '')
- expect(refSpec.length).toBe(1)
- expect(refSpec[0]).toBe('+refs/tags/my-tag:refs/tags/my-tag')
- })
- })
|