95 lines
2.2 KiB
Go
95 lines
2.2 KiB
Go
package database
|
|
|
|
import (
|
|
. "github.com/drone/drone/pkg/model"
|
|
"github.com/russross/meddler"
|
|
)
|
|
|
|
// Name of the Build table in the database
|
|
const buildTable = "builds"
|
|
|
|
// SQL Queries to retrieve a list of all Commits belonging to a Repo.
|
|
const buildStmt = `
|
|
SELECT id, commit_id, slug, status, started, finished, duration, created, updated, stdout
|
|
FROM builds
|
|
WHERE commit_id = ?
|
|
ORDER BY slug ASC
|
|
`
|
|
|
|
// SQL Queries to retrieve a Build by id.
|
|
const buildFindStmt = `
|
|
SELECT id, commit_id, slug, status, started, finished, duration, created, updated, stdout
|
|
FROM builds
|
|
WHERE id = ?
|
|
LIMIT 1
|
|
`
|
|
|
|
// SQL Queries to retrieve a Commit by name and repo id.
|
|
const buildFindSlugStmt = `
|
|
SELECT id, commit_id, slug, status, started, finished, duration, created, updated, stdout
|
|
FROM builds
|
|
WHERE slug = ? AND commit_id = ?
|
|
LIMIT 1
|
|
`
|
|
|
|
// SQL Queries to fail all builds that are running
|
|
const buildFailStartedStmt = `
|
|
UPDATE builds
|
|
SET status = 'Failure'
|
|
WHERE status = 'Started'
|
|
`
|
|
|
|
// SQL Queries to fail all builds that are pending
|
|
const buildFailPendingStmt = `
|
|
UPDATE builds
|
|
SET status = 'Failure'
|
|
WHERE status = 'Pending'
|
|
`
|
|
|
|
// SQL Queries to delete a Commit.
|
|
const buildDeleteStmt = `
|
|
DELETE FROM builds WHERE id = ?
|
|
`
|
|
|
|
// Returns the Build with the given ID.
|
|
func GetBuild(id int64) (*Build, error) {
|
|
build := Build{}
|
|
err := meddler.QueryRow(db, &build, buildFindStmt, id)
|
|
return &build, err
|
|
}
|
|
|
|
// Returns the Build with the given slug.
|
|
func GetBuildSlug(slug string, commit int64) (*Build, error) {
|
|
build := Build{}
|
|
err := meddler.QueryRow(db, &build, buildFindSlugStmt, slug, commit)
|
|
return &build, err
|
|
}
|
|
|
|
// Creates a new Build.
|
|
func SaveBuild(build *Build) error {
|
|
return meddler.Save(db, buildTable, build)
|
|
}
|
|
|
|
// Deletes an existing Build.
|
|
func DeleteBuild(id int64) error {
|
|
_, err := db.Exec(buildDeleteStmt, id)
|
|
return err
|
|
}
|
|
|
|
// Returns a list of all Builds associated
|
|
// with the specified Commit ID and branch.
|
|
func ListBuilds(id int64) ([]*Build, error) {
|
|
var builds []*Build
|
|
err := meddler.QueryAll(db, &builds, buildStmt, id)
|
|
return builds, err
|
|
}
|
|
|
|
func FailUnfinishedBuilds() error {
|
|
_, err := db.Exec(buildFailStartedStmt)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
_, err = db.Exec(buildFailPendingStmt)
|
|
return err
|
|
}
|