t / t5511-refspec.shon commit completion: improve ls-remote output filtering in __git_refs() (d8c0453)
   1#!/bin/sh
   2
   3test_description='refspec parsing'
   4
   5. ./test-lib.sh
   6
   7test_refspec () {
   8
   9        kind=$1 refspec=$2 expect=$3
  10        git config remote.frotz.url "." &&
  11        git config --remove-section remote.frotz &&
  12        git config remote.frotz.url "." &&
  13        git config "remote.frotz.$kind" "$refspec" &&
  14        if test "$expect" != invalid
  15        then
  16                title="$kind $refspec"
  17                test='git ls-remote frotz'
  18        else
  19                title="$kind $refspec (invalid)"
  20                test='test_must_fail git ls-remote frotz'
  21        fi
  22        test_expect_success "$title" "$test"
  23}
  24
  25test_refspec push ''                                            invalid
  26test_refspec push ':'
  27test_refspec push '::'                                          invalid
  28test_refspec push '+:'
  29
  30test_refspec fetch ''
  31test_refspec fetch ':'
  32test_refspec fetch '::'                                         invalid
  33
  34test_refspec push 'refs/heads/*:refs/remotes/frotz/*'
  35test_refspec push 'refs/heads/*:refs/remotes/frotz'             invalid
  36test_refspec push 'refs/heads:refs/remotes/frotz/*'             invalid
  37test_refspec push 'refs/heads/master:refs/remotes/frotz/xyzzy'
  38
  39
  40# These have invalid LHS, but we do not have a formal "valid sha-1
  41# expression syntax checker" so they are not checked with the current
  42# code.  They will be caught downstream anyway, but we may want to
  43# have tighter check later...
  44
  45: test_refspec push 'refs/heads/master::refs/remotes/frotz/xyzzy'       invalid
  46: test_refspec push 'refs/heads/maste :refs/remotes/frotz/xyzzy'        invalid
  47
  48test_refspec fetch 'refs/heads/*:refs/remotes/frotz/*'
  49test_refspec fetch 'refs/heads/*:refs/remotes/frotz'            invalid
  50test_refspec fetch 'refs/heads:refs/remotes/frotz/*'            invalid
  51test_refspec fetch 'refs/heads/master:refs/remotes/frotz/xyzzy'
  52test_refspec fetch 'refs/heads/master::refs/remotes/frotz/xyzzy'        invalid
  53test_refspec fetch 'refs/heads/maste :refs/remotes/frotz/xyzzy' invalid
  54
  55test_refspec push 'master~1:refs/remotes/frotz/backup'
  56test_refspec fetch 'master~1:refs/remotes/frotz/backup'         invalid
  57test_refspec push 'HEAD~4:refs/remotes/frotz/new'
  58test_refspec fetch 'HEAD~4:refs/remotes/frotz/new'              invalid
  59
  60test_refspec push 'HEAD'
  61test_refspec fetch 'HEAD'
  62test_refspec push 'refs/heads/ nitfol'                          invalid
  63test_refspec fetch 'refs/heads/ nitfol'                         invalid
  64
  65test_refspec push 'HEAD:'                                       invalid
  66test_refspec fetch 'HEAD:'
  67test_refspec push 'refs/heads/ nitfol:'                         invalid
  68test_refspec fetch 'refs/heads/ nitfol:'                        invalid
  69
  70test_refspec push ':refs/remotes/frotz/deleteme'
  71test_refspec fetch ':refs/remotes/frotz/HEAD-to-me'
  72test_refspec push ':refs/remotes/frotz/delete me'               invalid
  73test_refspec fetch ':refs/remotes/frotz/HEAD to me'             invalid
  74
  75test_refspec fetch 'refs/heads/*/for-linus:refs/remotes/mine/*-blah' invalid
  76test_refspec push 'refs/heads/*/for-linus:refs/remotes/mine/*-blah' invalid
  77
  78test_refspec fetch 'refs/heads*/for-linus:refs/remotes/mine/*' invalid
  79test_refspec push 'refs/heads*/for-linus:refs/remotes/mine/*' invalid
  80
  81test_refspec fetch 'refs/heads/*/*/for-linus:refs/remotes/mine/*' invalid
  82test_refspec push 'refs/heads/*/*/for-linus:refs/remotes/mine/*' invalid
  83
  84test_refspec fetch 'refs/heads/*/for-linus:refs/remotes/mine/*'
  85test_refspec push 'refs/heads/*/for-linus:refs/remotes/mine/*'
  86
  87test_done