mirror of
https://github.com/harness/drone.git
synced 2025-05-03 20:21:25 +08:00
346 lines
9.7 KiB
Go
346 lines
9.7 KiB
Go
// Copyright 2019 Drone.IO Inc. All rights reserved.
|
|
// Use of this source code is governed by the Drone Non-Commercial License
|
|
// that can be found in the LICENSE file.
|
|
|
|
package commit
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/drone/drone/mock"
|
|
"github.com/drone/drone/mock/mockscm"
|
|
"github.com/drone/drone/core"
|
|
"github.com/drone/go-scm/scm"
|
|
"github.com/golang/mock/gomock"
|
|
"github.com/google/go-cmp/cmp"
|
|
)
|
|
|
|
var noContext = context.Background()
|
|
|
|
func TestFind(t *testing.T) {
|
|
controller := gomock.NewController(t)
|
|
defer controller.Finish()
|
|
|
|
mockUser := &core.User{}
|
|
mockCommit := &scm.Commit{
|
|
Sha: "7fd1a60b01f91b314f59955a4e4d4e80d8edf11d",
|
|
Message: "Merge pull request #6 from Spaceghost/patch-1\n\nNew line at end of file.",
|
|
Author: scm.Signature{
|
|
Name: "The Octocat",
|
|
Email: "octocat@nowhere.com",
|
|
Date: time.Unix(1532303087, 0),
|
|
Login: "octocat",
|
|
Avatar: "https://avatars3.githubusercontent.com/u/583231?v=4",
|
|
},
|
|
Committer: scm.Signature{
|
|
Name: "The Octocat",
|
|
Email: "octocat@nowhere.com",
|
|
Date: time.Unix(1532303087, 0),
|
|
Login: "octocat",
|
|
Avatar: "https://avatars3.githubusercontent.com/u/583231?v=4",
|
|
},
|
|
Link: "https://github.com/octocat/Hello-World/commit/7fd1a60b01f91b314f59955a4e4d4e80d8edf11d",
|
|
}
|
|
|
|
mockRenewer := mock.NewMockRenewer(controller)
|
|
mockRenewer.EXPECT().Renew(gomock.Any(), mockUser, false).Return(nil)
|
|
|
|
mockGit := mockscm.NewMockGitService(controller)
|
|
mockGit.EXPECT().FindCommit(gomock.Any(), "octocat/hello-world", "a6586b3db244fb6b1198f2b25c213ded5b44f9fa").Return(mockCommit, nil, nil)
|
|
|
|
client := new(scm.Client)
|
|
client.Git = mockGit
|
|
|
|
want := &core.Commit{
|
|
Sha: "7fd1a60b01f91b314f59955a4e4d4e80d8edf11d",
|
|
Ref: "",
|
|
Message: "Merge pull request #6 from Spaceghost/patch-1\n\nNew line at end of file.",
|
|
Author: &core.Committer{
|
|
Name: "The Octocat",
|
|
Email: "octocat@nowhere.com",
|
|
Date: 1532303087,
|
|
Login: "octocat",
|
|
Avatar: "https://avatars3.githubusercontent.com/u/583231?v=4",
|
|
},
|
|
Committer: &core.Committer{
|
|
Name: "The Octocat",
|
|
Email: "octocat@nowhere.com",
|
|
Date: 1532303087,
|
|
Login: "octocat",
|
|
Avatar: "https://avatars3.githubusercontent.com/u/583231?v=4",
|
|
},
|
|
Link: "https://github.com/octocat/Hello-World/commit/7fd1a60b01f91b314f59955a4e4d4e80d8edf11d",
|
|
}
|
|
|
|
service := New(client, mockRenewer)
|
|
got, err := service.Find(noContext, mockUser, "octocat/hello-world", "a6586b3db244fb6b1198f2b25c213ded5b44f9fa")
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
if diff := cmp.Diff(got, want); diff != "" {
|
|
t.Errorf(diff)
|
|
}
|
|
}
|
|
|
|
func TestFind_Err(t *testing.T) {
|
|
controller := gomock.NewController(t)
|
|
defer controller.Finish()
|
|
|
|
mockUser := &core.User{}
|
|
|
|
mockRenewer := mock.NewMockRenewer(controller)
|
|
mockRenewer.EXPECT().Renew(gomock.Any(), mockUser, false).Return(nil)
|
|
|
|
mockGit := mockscm.NewMockGitService(controller)
|
|
mockGit.EXPECT().FindCommit(gomock.Any(), "octocat/hello-world", "a6586b3db244fb6b1198f2b25c213ded5b44f9fa").Return(nil, nil, scm.ErrNotFound)
|
|
|
|
client := new(scm.Client)
|
|
client.Git = mockGit
|
|
|
|
service := New(client, mockRenewer)
|
|
_, err := service.Find(noContext, mockUser, "octocat/hello-world", "a6586b3db244fb6b1198f2b25c213ded5b44f9fa")
|
|
if err != scm.ErrNotFound {
|
|
t.Errorf("Want not found error, got %v", err)
|
|
}
|
|
}
|
|
|
|
func TestFind_ErrRenew(t *testing.T) {
|
|
controller := gomock.NewController(t)
|
|
defer controller.Finish()
|
|
|
|
mockUser := &core.User{}
|
|
|
|
mockRenewer := mock.NewMockRenewer(controller)
|
|
mockRenewer.EXPECT().Renew(gomock.Any(), mockUser, false).Return(scm.ErrNotAuthorized)
|
|
|
|
service := New(nil, mockRenewer)
|
|
_, err := service.Find(noContext, mockUser, "octocat/hello-world", "a6586b3db244fb6b1198f2b25c213ded5b44f9fa")
|
|
if err != scm.ErrNotAuthorized {
|
|
t.Errorf("Want not authorized error, got %v", err)
|
|
}
|
|
}
|
|
|
|
func TestFindRef(t *testing.T) {
|
|
controller := gomock.NewController(t)
|
|
defer controller.Finish()
|
|
|
|
mockUser := &core.User{}
|
|
mockCommit := &scm.Commit{
|
|
Sha: "7fd1a60b01f91b314f59955a4e4d4e80d8edf11d",
|
|
Message: "Merge pull request #6 from Spaceghost/patch-1\n\nNew line at end of file.",
|
|
Author: scm.Signature{
|
|
Name: "The Octocat",
|
|
Email: "octocat@nowhere.com",
|
|
Date: time.Unix(1532303087, 0),
|
|
Login: "octocat",
|
|
Avatar: "https://avatars3.githubusercontent.com/u/583231?v=4",
|
|
},
|
|
Committer: scm.Signature{
|
|
Name: "The Octocat",
|
|
Email: "octocat@nowhere.com",
|
|
Date: time.Unix(1532303087, 0),
|
|
Login: "octocat",
|
|
Avatar: "https://avatars3.githubusercontent.com/u/583231?v=4",
|
|
},
|
|
Link: "https://github.com/octocat/Hello-World/commit/7fd1a60b01f91b314f59955a4e4d4e80d8edf11d",
|
|
}
|
|
|
|
mockRenewer := mock.NewMockRenewer(controller)
|
|
mockRenewer.EXPECT().Renew(gomock.Any(), mockUser, false).Return(nil)
|
|
|
|
mockGit := mockscm.NewMockGitService(controller)
|
|
mockGit.EXPECT().FindCommit(gomock.Any(), "octocat/hello-world", "master").Return(mockCommit, nil, nil)
|
|
|
|
client := new(scm.Client)
|
|
client.Git = mockGit
|
|
|
|
want := &core.Commit{
|
|
Sha: "7fd1a60b01f91b314f59955a4e4d4e80d8edf11d",
|
|
Ref: "master",
|
|
Message: "Merge pull request #6 from Spaceghost/patch-1\n\nNew line at end of file.",
|
|
Author: &core.Committer{
|
|
Name: "The Octocat",
|
|
Email: "octocat@nowhere.com",
|
|
Date: 1532303087,
|
|
Login: "octocat",
|
|
Avatar: "https://avatars3.githubusercontent.com/u/583231?v=4",
|
|
},
|
|
Committer: &core.Committer{
|
|
Name: "The Octocat",
|
|
Email: "octocat@nowhere.com",
|
|
Date: 1532303087,
|
|
Login: "octocat",
|
|
Avatar: "https://avatars3.githubusercontent.com/u/583231?v=4",
|
|
},
|
|
Link: "https://github.com/octocat/Hello-World/commit/7fd1a60b01f91b314f59955a4e4d4e80d8edf11d",
|
|
}
|
|
|
|
service := New(client, mockRenewer)
|
|
got, err := service.FindRef(noContext, mockUser, "octocat/hello-world", "master")
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
if diff := cmp.Diff(got, want); diff != "" {
|
|
t.Errorf(diff)
|
|
}
|
|
}
|
|
|
|
func TestFindRef_Err(t *testing.T) {
|
|
controller := gomock.NewController(t)
|
|
defer controller.Finish()
|
|
|
|
mockUser := &core.User{}
|
|
|
|
mockRenewer := mock.NewMockRenewer(controller)
|
|
mockRenewer.EXPECT().Renew(gomock.Any(), mockUser, false).Return(nil)
|
|
|
|
mockGit := mockscm.NewMockGitService(controller)
|
|
mockGit.EXPECT().FindCommit(gomock.Any(), "octocat/hello-world", "master").Return(nil, nil, scm.ErrNotFound)
|
|
|
|
client := new(scm.Client)
|
|
client.Git = mockGit
|
|
|
|
service := New(client, mockRenewer)
|
|
_, err := service.FindRef(noContext, mockUser, "octocat/hello-world", "master")
|
|
if err != scm.ErrNotFound {
|
|
t.Errorf("Want not found error, got %v", err)
|
|
}
|
|
}
|
|
|
|
func TestFindRef_ErrRenew(t *testing.T) {
|
|
controller := gomock.NewController(t)
|
|
defer controller.Finish()
|
|
|
|
mockUser := &core.User{}
|
|
|
|
mockRenewer := mock.NewMockRenewer(controller)
|
|
mockRenewer.EXPECT().Renew(gomock.Any(), mockUser, false).Return(scm.ErrNotAuthorized)
|
|
|
|
service := New(nil, mockRenewer)
|
|
_, err := service.FindRef(noContext, mockUser, "octocat/hello-world", "master")
|
|
if err != scm.ErrNotAuthorized {
|
|
t.Errorf("Want not authorized error, got %v", err)
|
|
}
|
|
}
|
|
|
|
func TestListChanges(t *testing.T) {
|
|
controller := gomock.NewController(t)
|
|
defer controller.Finish()
|
|
|
|
mockUser := &core.User{}
|
|
mockChanges := []*scm.Change{
|
|
{
|
|
Path: "file1",
|
|
Added: false,
|
|
Deleted: false,
|
|
Renamed: false,
|
|
},
|
|
{
|
|
Path: "file2",
|
|
Added: true,
|
|
Deleted: false,
|
|
Renamed: false,
|
|
},
|
|
{
|
|
Path: "file2",
|
|
Added: false,
|
|
Deleted: true,
|
|
Renamed: false,
|
|
},
|
|
{
|
|
Path: "file3",
|
|
Added: false,
|
|
Deleted: false,
|
|
Renamed: true,
|
|
},
|
|
}
|
|
|
|
mockRenewer := mock.NewMockRenewer(controller)
|
|
mockRenewer.EXPECT().Renew(gomock.Any(), mockUser, false).Return(nil)
|
|
|
|
mockGit := mockscm.NewMockGitService(controller)
|
|
mockGit.EXPECT().ListChanges(gomock.Any(), "octocat/hello-world", "a6586b3db244fb6b1198f2b25c213ded5b44f9fa", gomock.Any()).Return(mockChanges, nil, nil)
|
|
|
|
client := new(scm.Client)
|
|
client.Git = mockGit
|
|
|
|
want := []*core.Change{
|
|
{
|
|
Path: "file1",
|
|
Added: false,
|
|
Deleted: false,
|
|
Renamed: false,
|
|
},
|
|
{
|
|
Path: "file2",
|
|
Added: true,
|
|
Deleted: false,
|
|
Renamed: false,
|
|
},
|
|
{
|
|
Path: "file2",
|
|
Added: false,
|
|
Deleted: true,
|
|
Renamed: false,
|
|
},
|
|
{
|
|
Path: "file3",
|
|
Added: false,
|
|
Deleted: false,
|
|
Renamed: true,
|
|
},
|
|
}
|
|
|
|
service := New(client, mockRenewer)
|
|
got, err := service.ListChanges(noContext, mockUser, "octocat/hello-world", "a6586b3db244fb6b1198f2b25c213ded5b44f9fa", "master")
|
|
if err != nil {
|
|
t.Error(err)
|
|
}
|
|
|
|
if diff := cmp.Diff(got, want); diff != "" {
|
|
t.Errorf(diff)
|
|
}
|
|
}
|
|
|
|
func TestListChanges_Err(t *testing.T) {
|
|
controller := gomock.NewController(t)
|
|
defer controller.Finish()
|
|
|
|
mockUser := &core.User{}
|
|
|
|
mockRenewer := mock.NewMockRenewer(controller)
|
|
mockRenewer.EXPECT().Renew(gomock.Any(), mockUser, false).Return(nil)
|
|
|
|
mockGit := mockscm.NewMockGitService(controller)
|
|
mockGit.EXPECT().ListChanges(gomock.Any(), "octocat/hello-world", "a6586b3db244fb6b1198f2b25c213ded5b44f9fa", gomock.Any()).Return(nil, nil, scm.ErrNotFound)
|
|
|
|
client := new(scm.Client)
|
|
client.Git = mockGit
|
|
|
|
service := New(client, mockRenewer)
|
|
_, err := service.ListChanges(noContext, mockUser, "octocat/hello-world", "a6586b3db244fb6b1198f2b25c213ded5b44f9fa", "master")
|
|
if err != scm.ErrNotFound {
|
|
t.Errorf("Want not found error, got %v", err)
|
|
}
|
|
}
|
|
|
|
func TestListChanges_ErrRenew(t *testing.T) {
|
|
controller := gomock.NewController(t)
|
|
defer controller.Finish()
|
|
|
|
mockUser := &core.User{}
|
|
|
|
mockRenewer := mock.NewMockRenewer(controller)
|
|
mockRenewer.EXPECT().Renew(gomock.Any(), mockUser, false).Return(scm.ErrNotAuthorized)
|
|
|
|
service := New(nil, mockRenewer)
|
|
_, err := service.ListChanges(noContext, mockUser, "octocat/hello-world", "a6586b3db244fb6b1198f2b25c213ded5b44f9fa", "master")
|
|
if err != scm.ErrNotAuthorized {
|
|
t.Errorf("Want not authorized error, got %v", err)
|
|
}
|
|
}
|