123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- package gitutil
- import (
- "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")},
- }
- SetMockModuleStore(t, &MockModuleStore{
- 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
- },
- 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
- },
- 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
- },
- 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
- },
- 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
- },
- pullRequestMeta: Module.PullRequestMeta,
- })
- 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)
- }
|