Skip to content

Commit

Permalink
Merge branch 'main' into feat/build-dag
Browse files Browse the repository at this point in the history
  • Loading branch information
plyr4 authored Oct 27, 2023
2 parents 1c06bd8 + 262d7f0 commit 502bb68
Show file tree
Hide file tree
Showing 8 changed files with 30 additions and 34 deletions.
8 changes: 4 additions & 4 deletions api/build/skip.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,25 +13,25 @@ import (
func SkipEmptyBuild(p *pipeline.Build) string {
if len(p.Stages) == 1 {
if p.Stages[0].Name == "init" {
return "skipping build since only init stage found"
return "skipping build since only init stage found — it is likely no rulesets matched for the webhook payload"
}
}

if len(p.Stages) == 2 {
if p.Stages[0].Name == "init" && p.Stages[1].Name == "clone" {
return "skipping build since only init and clone stages found"
return "skipping build since only init and clone stages found — it is likely no rulesets matched for the webhook payload"
}
}

if len(p.Steps) == 1 {
if p.Steps[0].Name == "init" {
return "skipping build since only init step found"
return "skipping build since only init step found — it is likely no rulesets matched for the webhook payload"
}
}

if len(p.Steps) == 2 {
if p.Steps[0].Name == "init" && p.Steps[1].Name == "clone" {
return "skipping build since only init and clone steps found"
return "skipping build since only init and clone steps found — it is likely no rulesets matched for the webhook payload"
}
}

Expand Down
8 changes: 4 additions & 4 deletions api/build/skip_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,15 +22,15 @@ func Test_SkipEmptyBuild(t *testing.T) {
{
Name: "init",
},
}}}, "skipping build since only init stage found"},
}}}, "skipping build since only init stage found — it is likely no rulesets matched for the webhook payload"},
{"init and clone stages", args{p: &pipeline.Build{Stages: []*pipeline.Stage{
{
Name: "init",
},
{
Name: "clone",
},
}}}, "skipping build since only init and clone stages found"},
}}}, "skipping build since only init and clone stages found — it is likely no rulesets matched for the webhook payload"},
{"three stages", args{p: &pipeline.Build{Stages: []*pipeline.Stage{
{
Name: "init",
Expand All @@ -46,15 +46,15 @@ func Test_SkipEmptyBuild(t *testing.T) {
{
Name: "init",
},
}}}, "skipping build since only init step found"},
}}}, "skipping build since only init step found — it is likely no rulesets matched for the webhook payload"},
{"init and clone steps", args{p: &pipeline.Build{Steps: []*pipeline.Container{
{
Name: "init",
},
{
Name: "clone",
},
}}}, "skipping build since only init and clone steps found"},
}}}, "skipping build since only init and clone steps found — it is likely no rulesets matched for the webhook payload"},
{"three steps", args{p: &pipeline.Build{Steps: []*pipeline.Container{
{
Name: "init",
Expand Down
14 changes: 5 additions & 9 deletions api/scm/sync.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ import (
"github.com/sirupsen/logrus"
)

// swagger:operation GET /api/v1/scm/repos/{org}/{repo}/sync scm SyncRepo
// swagger:operation PATCH /api/v1/scm/repos/{org}/{repo}/sync scm SyncRepo
//
// Sync up scm service and database in the context of a specific repo
//
Expand Down Expand Up @@ -125,11 +125,9 @@ func SyncRepo(c *gin.Context) {
// update webhook
webhookExists, err := scm.FromContext(c).Update(ctx, u, r, lastHook.GetWebhookID())
if err != nil {

// if webhook has been manually deleted from GitHub,
// set to inactive in database
if !webhookExists {

r.SetActive(false)

_, err := database.FromContext(c).UpdateRepo(ctx, r)
Expand All @@ -144,15 +142,13 @@ func SyncRepo(c *gin.Context) {
c.JSON(http.StatusOK, fmt.Sprintf("webhook not found, repo %s deactivated", r.GetFullName()))

return
}

} else {

retErr := fmt.Errorf("unable to update repo webhook for %s: %w", r.GetFullName(), err)
retErr := fmt.Errorf("unable to update repo webhook for %s: %w", r.GetFullName(), err)

util.HandleError(c, http.StatusInternalServerError, retErr)
util.HandleError(c, http.StatusInternalServerError, retErr)

return
}
return
}
}

Expand Down
14 changes: 5 additions & 9 deletions api/scm/sync_org.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ import (
"github.com/sirupsen/logrus"
)

// swagger:operation GET /api/v1/scm/orgs/{org}/sync scm SyncReposForOrg
// swagger:operation PATCH /api/v1/scm/orgs/{org}/sync scm SyncReposForOrg
//
// Sync up repos from scm service and database in a specified org
//
Expand Down Expand Up @@ -138,11 +138,9 @@ func SyncReposForOrg(c *gin.Context) {
// update webhook
webhookExists, err := scm.FromContext(c).Update(ctx, u, repo, lastHook.GetWebhookID())
if err != nil {

// if webhook has been manually deleted from GitHub,
// set to inactive in database
if !webhookExists {

repo.SetActive(false)

_, err := database.FromContext(c).UpdateRepo(ctx, repo)
Expand All @@ -155,15 +153,13 @@ func SyncReposForOrg(c *gin.Context) {
}

continue
}

} else {

retErr := fmt.Errorf("unable to update repo webhook for %s: %w", repo.GetFullName(), err)
retErr := fmt.Errorf("unable to update repo webhook for %s: %w", repo.GetFullName(), err)

util.HandleError(c, http.StatusInternalServerError, retErr)
util.HandleError(c, http.StatusInternalServerError, retErr)

return
}
return
}
}
}
Expand Down
4 changes: 4 additions & 0 deletions api/webhook/post.go
Original file line number Diff line number Diff line change
Expand Up @@ -532,6 +532,10 @@ func PostWebhook(c *gin.Context) {
// set build to successful status
b.SetStatus(constants.StatusSkipped)

// set hook status and message
h.SetStatus(constants.StatusSkipped)
h.SetError(skip)

// send API call to set the status on the commit
err = scm.FromContext(c).Status(ctx, u, b, repo.GetOrg(), repo.GetName())
if err != nil {
Expand Down
4 changes: 2 additions & 2 deletions mock/server/scm.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import (
"github.com/go-vela/types"
)

// syncRepo has a param :repo returns mock JSON for a http GET.
// syncRepo has a param :repo returns mock JSON for a http PATCH.
//
// Pass "not-found" to :repo to test receiving a http 404 response.
func syncRepo(c *gin.Context) {
Expand All @@ -27,7 +27,7 @@ func syncRepo(c *gin.Context) {
c.JSON(http.StatusOK, fmt.Sprintf("Repo %s has been synced", r))
}

// syncRepos has a param :org returns mock JSON for a http GET.
// syncRepos has a param :org returns mock JSON for a http PATCH.
//
// Pass "not-found" to :repo to test receiving a http 404 response.
func syncRepos(c *gin.Context) {
Expand Down
4 changes: 2 additions & 2 deletions mock/server/server.go
Original file line number Diff line number Diff line change
Expand Up @@ -83,8 +83,8 @@ func FakeHandler() http.Handler {
e.DELETE("/api/v1/repos/:org/:repo", removeRepo)
e.PATCH("/api/v1/repos/:org/:repo/repair", repairRepo)
e.PATCH("/api/v1/repos/:org/:repo/chown", chownRepo)
e.GET("/api/v1/scm/repos/:org/:repo/sync", syncRepo)
e.GET("/api/v1/scm/orgs/:org/sync", syncRepos)
e.PATCH("/api/v1/scm/repos/:org/:repo/sync", syncRepo)
e.PATCH("/api/v1/scm/orgs/:org/sync", syncRepos)

// mock endpoints for secret calls
e.GET("/api/v1/secrets/:engine/:type/:org/:name/:secret", getSecret)
Expand Down
8 changes: 4 additions & 4 deletions router/scm.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,16 @@ import (
// ScmHandlers is a function that extends the provided base router group
// with the API handlers for source code management functionality.
//
// GET /api/v1/scm/orgs/:org/sync
// GET /api/v1/scm/repos/:org/:repo/sync .
// PATCH /api/v1/scm/orgs/:org/sync
// PATCH /api/v1/scm/repos/:org/:repo/sync .
func ScmHandlers(base *gin.RouterGroup) {
// SCM orgs endpoints
orgs := base.Group("/scm/orgs")
{
// SCM org endpoints
org := orgs.Group("/:org", org.Establish())
{
org.GET("/sync", scm.SyncReposForOrg)
org.PATCH("/sync", scm.SyncReposForOrg)
} // end of SCM org endpoints
} // end of SCM orgs endpoints

Expand All @@ -31,7 +31,7 @@ func ScmHandlers(base *gin.RouterGroup) {
// SCM repo endpoints
repo := repos.Group("/:org/:repo", org.Establish(), repo.Establish())
{
repo.GET("/sync", scm.SyncRepo)
repo.PATCH("/sync", scm.SyncRepo)
} // end of SCM repo endpoints
} // end of SCM repos endpoints
}

0 comments on commit 502bb68

Please sign in to comment.