| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 | // Copyright 2020 The Gogs Authors. All rights reserved.// Use of this source code is governed by a MIT-style// license that can be found in the LICENSE file.package gitutilimport (	"fmt"	"testing"	"github.com/gogs/git-module"	"github.com/pkg/errors"	"github.com/stretchr/testify/assert")func TestModuler_PullRequestMeta(t *testing.T) {	headPath := "/head/path"	basePath := "/base/path"	headBranch := "head_branch"	baseBranch := "base_branch"	mergeBase := "MERGE-BASE"	changedFiles := []string{"a.go", "b.txt"}	commits := []*git.Commit{		{ID: git.MustIDFromString("adfd6da3c0a3fb038393144becbf37f14f780087")},	}	MockModule.RepoAddRemote = func(repoPath, name, url string, opts ...git.AddRemoteOptions) error {		if repoPath != headPath {			return fmt.Errorf("repoPath: want %q but got %q", headPath, repoPath)		} else if name == "" {			return errors.New("empty name")		} else if url != basePath {			return fmt.Errorf("url: want %q but got %q", basePath, url)		}		if len(opts) == 0 {			return errors.New("no options")		} else if !opts[0].Fetch {			return fmt.Errorf("opts.Fetch: want %v but got %v", true, opts[0].Fetch)		}		return nil	}	MockModule.RepoMergeBase = func(repoPath, base, head string, opts ...git.MergeBaseOptions) (string, error) {		if repoPath != headPath {			return "", fmt.Errorf("repoPath: want %q but got %q", headPath, repoPath)		} else if base == "" {			return "", errors.New("empty base")		} else if head != headBranch {			return "", fmt.Errorf("head: want %q but got %q", headBranch, head)		}		return mergeBase, nil	}	MockModule.RepoLog = func(repoPath, rev string, opts ...git.LogOptions) ([]*git.Commit, error) {		if repoPath != headPath {			return nil, fmt.Errorf("repoPath: want %q but got %q", headPath, repoPath)		}		expRev := mergeBase + "..." + headBranch		if rev != expRev {			return nil, fmt.Errorf("rev: want %q but got %q", expRev, rev)		}		return commits, nil	}	MockModule.RepoDiffNameOnly = func(repoPath, base, head string, opts ...git.DiffNameOnlyOptions) ([]string, error) {		if repoPath != headPath {			return nil, fmt.Errorf("repoPath: want %q but got %q", headPath, repoPath)		} else if base == "" {			return nil, errors.New("empty base")		} else if head != headBranch {			return nil, fmt.Errorf("head: want %q but got %q", headBranch, head)		}		if len(opts) == 0 {			return nil, errors.New("no options")		} else if !opts[0].NeedsMergeBase {			return nil, fmt.Errorf("opts.NeedsMergeBase: want %v but got %v", true, opts[0].NeedsMergeBase)		}		return changedFiles, nil	}	MockModule.RepoRemoveRemote = func(repoPath, name string, opts ...git.RemoveRemoteOptions) error {		if repoPath != headPath {			return fmt.Errorf("repoPath: want %q but got %q", headPath, repoPath)		} else if name == "" {			return errors.New("empty name")		}		return nil	}	defer func() {		MockModule = MockModuleStore{}	}()	meta, err := Module.PullRequestMeta(headPath, basePath, headBranch, baseBranch)	if err != nil {		t.Fatal(err)	}	expMeta := &PullRequestMeta{		MergeBase: mergeBase,		Commits:   commits,		NumFiles:  2,	}	assert.Equal(t, expMeta, meta)}
 |