mirror of
				https://gitea.com/Lydanne/buildx.git
				synced 2025-10-30 07:33:42 +08:00 
			
		
		
		
	Merge pull request #1635 from crazy-max/v0.10_backport_fix-git-ambiguous
[v0.10 backport] build: fix git ambiguous argument
This commit is contained in:
		| @@ -80,11 +80,11 @@ func (c *Git) RemoteURL() (string, error) { | |||||||
| } | } | ||||||
|  |  | ||||||
| func (c *Git) FullCommit() (string, error) { | func (c *Git) FullCommit() (string, error) { | ||||||
| 	return c.clean(c.run("show", "--format=%H", "HEAD", "--quiet")) | 	return c.clean(c.run("show", "--format=%H", "HEAD", "--quiet", "--")) | ||||||
| } | } | ||||||
|  |  | ||||||
| func (c *Git) ShortCommit() (string, error) { | func (c *Git) ShortCommit() (string, error) { | ||||||
| 	return c.clean(c.run("show", "--format=%h", "HEAD", "--quiet")) | 	return c.clean(c.run("show", "--format=%h", "HEAD", "--quiet", "--")) | ||||||
| } | } | ||||||
|  |  | ||||||
| func (c *Git) Tag() (string, error) { | func (c *Git) Tag() (string, error) { | ||||||
|   | |||||||
| @@ -56,6 +56,20 @@ func TestGitFullCommitErr(t *testing.T) { | |||||||
| 	_, err = c.FullCommit() | 	_, err = c.FullCommit() | ||||||
| 	require.Error(t, err) | 	require.Error(t, err) | ||||||
| 	require.True(t, IsUnknownRevision(err)) | 	require.True(t, IsUnknownRevision(err)) | ||||||
|  | 	require.False(t, IsAmbiguousArgument(err)) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func TestGitShortCommitErr(t *testing.T) { | ||||||
|  | 	Mktmp(t) | ||||||
|  | 	c, err := New() | ||||||
|  | 	require.NoError(t, err) | ||||||
|  |  | ||||||
|  | 	GitInit(c, t) | ||||||
|  |  | ||||||
|  | 	_, err = c.ShortCommit() | ||||||
|  | 	require.Error(t, err) | ||||||
|  | 	require.True(t, IsUnknownRevision(err)) | ||||||
|  | 	require.False(t, IsAmbiguousArgument(err)) | ||||||
| } | } | ||||||
|  |  | ||||||
| func TestGitTagsPointsAt(t *testing.T) { | func TestGitTagsPointsAt(t *testing.T) { | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ package gitutil | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"os" | 	"os" | ||||||
|  | 	"strings" | ||||||
| 	"testing" | 	"testing" | ||||||
|  |  | ||||||
| 	"github.com/stretchr/testify/require" | 	"github.com/stretchr/testify/require" | ||||||
| @@ -73,3 +74,11 @@ func fakeGit(c *Git, args ...string) (string, error) { | |||||||
| 	allArgs = append(allArgs, args...) | 	allArgs = append(allArgs, args...) | ||||||
| 	return c.clean(c.run(allArgs...)) | 	return c.clean(c.run(allArgs...)) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func IsAmbiguousArgument(err error) bool { | ||||||
|  | 	if err == nil { | ||||||
|  | 		return false | ||||||
|  | 	} | ||||||
|  | 	errMsg := strings.ToLower(err.Error()) | ||||||
|  | 	return strings.Contains(errMsg, "use '--' to separate paths from revisions") | ||||||
|  | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 CrazyMax
					CrazyMax