Skip to content

Commit

Permalink
Merge pull request harness#2147 from bradrydzewski/master
Browse files Browse the repository at this point in the history
ability to force kill zombie builds
  • Loading branch information
bradrydzewski authored Aug 1, 2017
2 parents 1b79d1f + 7a4879c commit dba3701
Show file tree
Hide file tree
Showing 4 changed files with 54 additions and 3 deletions.
4 changes: 2 additions & 2 deletions .drone.yml
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ pipeline:
image: plugins/docker
repo: drone/drone
secrets: [ docker_username, docker_password ]
tag: [ 0.8, 0.8.0 ]
tag: [ 0.8, 0.8.0, 0.8.0-rc.3 ]
when:
event: tag

Expand All @@ -89,7 +89,7 @@ pipeline:
repo: drone/agent
dockerfile: Dockerfile.agent
secrets: [ docker_username, docker_password ]
tag: [ 0.8, 0.8.0 ]
tag: [ 0.8, 0.8.0, 0.8.0-rc.3 ]
when:
event: tag

Expand Down
1 change: 1 addition & 0 deletions router/router.go
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,7 @@ func Load(mux *httptreemux.ContextMux, middleware ...gin.HandlerFunc) http.Handl
repo.POST("/repair", session.MustRepoAdmin(), server.RepairRepo)

repo.POST("/builds/:number", session.MustPush, server.PostBuild)
repo.DELETE("/builds/:number", session.MustAdmin(), server.ZombieKill)
repo.POST("/builds/:number/approve", session.MustPush, server.PostApproval)
repo.POST("/builds/:number/decline", session.MustPush, server.PostDecline)
repo.DELETE("/builds/:number/:job", session.MustPush, server.DeleteBuild)
Expand Down
50 changes: 50 additions & 0 deletions server/build.go
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,56 @@ func DeleteBuild(c *gin.Context) {
c.String(204, "")
}

// ZombieKill kills zombie processes stuck in an infinite pending
// or running state. This can only be invoked by administrators and
// may have negative effects.
func ZombieKill(c *gin.Context) {
repo := session.Repo(c)

// parse the build number and job sequence number from
// the repquest parameter.
num, _ := strconv.Atoi(c.Params.ByName("number"))

build, err := store.GetBuildNumber(c, repo, num)
if err != nil {
c.AbortWithError(404, err)
return
}

procs, err := store.FromContext(c).ProcList(build)
if err != nil {
c.AbortWithError(404, err)
return
}

if build.Status != model.StatusRunning {
c.String(400, "Cannot force cancel a non-running build")
return
}

for _, proc := range procs {
if proc.Running() {
proc.State = model.StatusKilled
proc.ExitCode = 137
proc.Stopped = time.Now().Unix()
if proc.Started == 0 {
proc.Started = proc.Stopped
}
}
}

for _, proc := range procs {
store.FromContext(c).ProcUpdate(proc)
Config.Services.Queue.Error(context.Background(), fmt.Sprint(proc.ID), queue.ErrCancel)
}

build.Status = model.StatusKilled
build.Finished = time.Now().Unix()
store.FromContext(c).UpdateBuild(build)

c.String(204, "")
}

func PostApproval(c *gin.Context) {
var (
remote_ = remote.FromContext(c)
Expand Down
2 changes: 1 addition & 1 deletion version/version.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ var (
// VersionPatch is for backwards-compatible bug fixes
VersionPatch int64 = 0
// VersionPre indicates prerelease
VersionPre string
VersionPre string = "rc.3"
// VersionDev indicates development branch. Releases will be empty string.
VersionDev string
)
Expand Down

0 comments on commit dba3701

Please sign in to comment.