mirror of
				https://github.com/woodpecker-ci/woodpecker.git
				synced 2025-10-26 18:39:56 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			253 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			253 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package database
 | |
| 
 | |
| import (
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/drone/drone/shared/model"
 | |
| 	"github.com/franela/goblin"
 | |
| )
 | |
| 
 | |
| func TestCommitstore(t *testing.T) {
 | |
| 	db := mustConnectTest()
 | |
| 	cs := NewCommitstore(db)
 | |
| 	rs := NewRepostore(db)
 | |
| 	ps := NewPermstore(db)
 | |
| 	defer db.Close()
 | |
| 
 | |
| 	g := goblin.Goblin(t)
 | |
| 	g.Describe("Commitstore", func() {
 | |
| 
 | |
| 		// before each test be sure to purge the package
 | |
| 		// table data from the database.
 | |
| 		g.BeforeEach(func() {
 | |
| 			db.Exec("DELETE FROM perms")
 | |
| 			db.Exec("DELETE FROM repos")
 | |
| 			db.Exec("DELETE FROM commits")
 | |
| 		})
 | |
| 
 | |
| 		g.It("Should Put a Commit", func() {
 | |
| 			commit := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 			}
 | |
| 			err := cs.PutCommit(&commit)
 | |
| 			g.Assert(err == nil).IsTrue()
 | |
| 			g.Assert(commit.ID != 0).IsTrue()
 | |
| 		})
 | |
| 
 | |
| 		g.It("Should Post a Commit", func() {
 | |
| 			commit := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 			}
 | |
| 			err := cs.PostCommit(&commit)
 | |
| 			g.Assert(err == nil).IsTrue()
 | |
| 			g.Assert(commit.ID != 0).IsTrue()
 | |
| 		})
 | |
| 
 | |
| 		g.It("Should Get a Commit by ID", func() {
 | |
| 			commit := model.Commit{
 | |
| 				RepoID:  1,
 | |
| 				Branch:  "foo",
 | |
| 				Sha:     "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 				Status:  model.StatusSuccess,
 | |
| 				Created: 1398065343,
 | |
| 				Updated: 1398065344,
 | |
| 			}
 | |
| 			cs.PostCommit(&commit)
 | |
| 			getcommit, err := cs.GetCommit(commit.ID)
 | |
| 			g.Assert(err == nil).IsTrue()
 | |
| 			g.Assert(commit.ID).Equal(getcommit.ID)
 | |
| 			g.Assert(commit.RepoID).Equal(getcommit.RepoID)
 | |
| 			g.Assert(commit.Branch).Equal(getcommit.Branch)
 | |
| 			g.Assert(commit.Sha).Equal(getcommit.Sha)
 | |
| 			g.Assert(commit.Status).Equal(getcommit.Status)
 | |
| 			g.Assert(commit.Created).Equal(getcommit.Created)
 | |
| 			g.Assert(commit.Updated).Equal(getcommit.Updated)
 | |
| 		})
 | |
| 
 | |
| 		g.It("Should Delete a Commit", func() {
 | |
| 			commit := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 			}
 | |
| 			cs.PostCommit(&commit)
 | |
| 			_, err1 := cs.GetCommit(commit.ID)
 | |
| 			err2 := cs.DelCommit(&commit)
 | |
| 			_, err3 := cs.GetCommit(commit.ID)
 | |
| 			g.Assert(err1 == nil).IsTrue()
 | |
| 			g.Assert(err2 == nil).IsTrue()
 | |
| 			g.Assert(err3 == nil).IsFalse()
 | |
| 		})
 | |
| 
 | |
| 		g.It("Should Kill Pending or Started Commits", func() {
 | |
| 			commit1 := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 				Status: model.StatusEnqueue,
 | |
| 			}
 | |
| 			commit2 := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "bar",
 | |
| 				Sha:    "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 				Status: model.StatusEnqueue,
 | |
| 			}
 | |
| 			cs.PutCommit(&commit1)
 | |
| 			cs.PutCommit(&commit2)
 | |
| 			err := cs.KillCommits()
 | |
| 			g.Assert(err == nil).IsTrue()
 | |
| 			getcommit1, _ := cs.GetCommit(commit1.ID)
 | |
| 			getcommit2, _ := cs.GetCommit(commit1.ID)
 | |
| 			g.Assert(getcommit1.Status).Equal(model.StatusKilled)
 | |
| 			g.Assert(getcommit2.Status).Equal(model.StatusKilled)
 | |
| 		})
 | |
| 
 | |
| 		g.It("Should Get a Commit by Sha", func() {
 | |
| 			commit := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 			}
 | |
| 			cs.PostCommit(&commit)
 | |
| 			getcommit, err := cs.GetCommitSha(&model.Repo{ID: 1}, commit.Branch, commit.Sha)
 | |
| 			g.Assert(err == nil).IsTrue()
 | |
| 			g.Assert(commit.ID).Equal(getcommit.ID)
 | |
| 			g.Assert(commit.RepoID).Equal(getcommit.RepoID)
 | |
| 			g.Assert(commit.Branch).Equal(getcommit.Branch)
 | |
| 			g.Assert(commit.Sha).Equal(getcommit.Sha)
 | |
| 		})
 | |
| 
 | |
| 		g.It("Should get the last Commit by Branch", func() {
 | |
| 			commit1 := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 				Status: model.StatusFailure,
 | |
| 			}
 | |
| 			commit2 := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "0a74b46d7d62b737b6906897f48dbeb72cfda222",
 | |
| 				Status: model.StatusSuccess,
 | |
| 			}
 | |
| 			cs.PutCommit(&commit1)
 | |
| 			cs.PutCommit(&commit2)
 | |
| 			lastcommit, err := cs.GetCommitLast(&model.Repo{ID: 1}, commit1.Branch)
 | |
| 			g.Assert(err == nil).IsTrue()
 | |
| 			g.Assert(commit2.ID).Equal(lastcommit.ID)
 | |
| 			g.Assert(commit2.RepoID).Equal(lastcommit.RepoID)
 | |
| 			g.Assert(commit2.Branch).Equal(lastcommit.Branch)
 | |
| 			g.Assert(commit2.Sha).Equal(lastcommit.Sha)
 | |
| 		})
 | |
| 
 | |
| 		g.It("Should get the recent Commit List for a Repo", func() {
 | |
| 			commit1 := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 				Status: model.StatusFailure,
 | |
| 			}
 | |
| 			commit2 := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "0a74b46d7d62b737b6906897f48dbeb72cfda222",
 | |
| 				Status: model.StatusSuccess,
 | |
| 			}
 | |
| 			cs.PutCommit(&commit1)
 | |
| 			cs.PutCommit(&commit2)
 | |
| 			commits, err := cs.GetCommitList(&model.Repo{ID: 1})
 | |
| 			g.Assert(err == nil).IsTrue()
 | |
| 			g.Assert(len(commits)).Equal(2)
 | |
| 			g.Assert(commits[0].ID).Equal(commit2.ID)
 | |
| 			g.Assert(commits[0].RepoID).Equal(commit2.RepoID)
 | |
| 			g.Assert(commits[0].Branch).Equal(commit2.Branch)
 | |
| 			g.Assert(commits[0].Sha).Equal(commit2.Sha)
 | |
| 		})
 | |
| 
 | |
| 		g.It("Should get the recent Commit List for a User", func() {
 | |
| 			repo1 := model.Repo{
 | |
| 				UserID: 1,
 | |
| 				Remote: "enterprise.github.com",
 | |
| 				Host:   "github.drone.io",
 | |
| 				Owner:  "bradrydzewski",
 | |
| 				Name:   "drone",
 | |
| 			}
 | |
| 			repo2 := model.Repo{
 | |
| 				UserID: 1,
 | |
| 				Remote: "enterprise.github.com",
 | |
| 				Host:   "github.drone.io",
 | |
| 				Owner:  "drone",
 | |
| 				Name:   "drone",
 | |
| 			}
 | |
| 			rs.PostRepo(&repo1)
 | |
| 			rs.PostRepo(&repo2)
 | |
| 			commit1 := model.Commit{
 | |
| 				RepoID: repo1.ID,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 				Status: model.StatusFailure,
 | |
| 			}
 | |
| 			commit2 := model.Commit{
 | |
| 				RepoID: repo2.ID,
 | |
| 				Branch: "bar",
 | |
| 				Sha:    "0a74b46d7d62b737b6906897f48dbeb72cfda222",
 | |
| 				Status: model.StatusSuccess,
 | |
| 			}
 | |
| 			commit3 := model.Commit{
 | |
| 				RepoID: 99999,
 | |
| 				Branch: "baz",
 | |
| 				Sha:    "0a74b46d7d62b737b6906897f48dbeb72cfda222",
 | |
| 				Status: model.StatusSuccess,
 | |
| 			}
 | |
| 			cs.PostCommit(&commit1)
 | |
| 			cs.PostCommit(&commit2)
 | |
| 			cs.PostCommit(&commit3)
 | |
| 			perm1 := model.Perm{
 | |
| 				RepoID: repo1.ID,
 | |
| 				UserID: 1,
 | |
| 				Read:   true,
 | |
| 				Write:  true,
 | |
| 				Admin:  true,
 | |
| 			}
 | |
| 			perm2 := model.Perm{
 | |
| 				RepoID: repo2.ID,
 | |
| 				UserID: 1,
 | |
| 				Read:   true,
 | |
| 				Write:  true,
 | |
| 				Admin:  true,
 | |
| 			}
 | |
| 			ps.PostPerm(&perm1)
 | |
| 			ps.PostPerm(&perm2)
 | |
| 			commits, err := cs.GetCommitListUser(&model.User{ID: 1})
 | |
| 			g.Assert(err == nil).IsTrue()
 | |
| 			g.Assert(len(commits)).Equal(2)
 | |
| 			g.Assert(commits[0].RepoID).Equal(commit1.RepoID)
 | |
| 			g.Assert(commits[0].Branch).Equal(commit1.Branch)
 | |
| 			g.Assert(commits[0].Sha).Equal(commit1.Sha)
 | |
| 		})
 | |
| 
 | |
| 		g.It("Should enforce unique Sha + Branch", func() {
 | |
| 			commit1 := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 				Status: model.StatusEnqueue,
 | |
| 			}
 | |
| 			commit2 := model.Commit{
 | |
| 				RepoID: 1,
 | |
| 				Branch: "foo",
 | |
| 				Sha:    "85f8c029b902ed9400bc600bac301a0aadb144ac",
 | |
| 				Status: model.StatusEnqueue,
 | |
| 			}
 | |
| 			err1 := cs.PutCommit(&commit1)
 | |
| 			err2 := cs.PutCommit(&commit2)
 | |
| 			g.Assert(err1 == nil).IsTrue()
 | |
| 			g.Assert(err2 == nil).IsFalse()
 | |
| 		})
 | |
| 	})
 | |
| }
 |