Calculate build number on creation (#615)

* Calculate build number on creation
* Delete repo.Counter (form code and database)
This commit is contained in:
6543 2021-12-18 20:37:51 +01:00 committed by GitHub
parent 1d66cd1d0d
commit f4c73792f3
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 52 additions and 48 deletions

View file

@ -147,9 +147,6 @@ func PatchRepo(c *gin.Context) {
return return
} }
} }
if in.BuildCounter != nil {
repo.Counter = *in.BuildCounter
}
err := _store.UpdateRepo(repo) err := _store.UpdateRepo(repo)
if err != nil { if err != nil {

View file

@ -42,8 +42,6 @@ type Repo struct {
IsGated bool `json:"gated" xorm:"repo_gated"` IsGated bool `json:"gated" xorm:"repo_gated"`
IsActive bool `json:"active" xorm:"repo_active"` IsActive bool `json:"active" xorm:"repo_active"`
AllowPull bool `json:"allow_pr" xorm:"repo_allow_pr"` AllowPull bool `json:"allow_pr" xorm:"repo_allow_pr"`
// Counter is used as index to determine new build numbers
Counter int64 `json:"last_build" xorm:"NOT NULL DEFAULT 0 'repo_counter'"`
Config string `json:"config_file" xorm:"varchar(500) 'repo_config_path'"` Config string `json:"config_file" xorm:"varchar(500) 'repo_config_path'"`
Hash string `json:"-" xorm:"varchar(500) 'repo_hash'"` Hash string `json:"-" xorm:"varchar(500) 'repo_hash'"`
Perm *Perm `json:"-" xorm:"-"` Perm *Perm `json:"-" xorm:"-"`
@ -98,5 +96,4 @@ type RepoPatch struct {
Timeout *int64 `json:"timeout,omitempty"` Timeout *int64 `json:"timeout,omitempty"`
Visibility *string `json:"visibility,omitempty"` Visibility *string `json:"visibility,omitempty"`
AllowPull *bool `json:"allow_pr,omitempty"` AllowPull *bool `json:"allow_pr,omitempty"`
BuildCounter *int64 `json:"build_counter,omitempty"`
} }

View file

@ -91,17 +91,13 @@ func (s storage) CreateBuild(build *model.Build, procList ...*model.Proc) error
return err return err
} }
// increment counter // calc build number
if _, err := sess.ID(build.RepoID).Incr("repo_counter").Update(new(model.Repo)); err != nil { var number int64
if _, err := sess.SQL("SELECT MAX(build_number) FROM `builds` WHERE build_repo_id = ?", build.RepoID).Get(&number); err != nil {
return err return err
} }
build.Number = number + 1
repo := new(model.Repo)
if err := wrapGet(sess.ID(build.RepoID).Get(repo)); err != nil {
return err
}
build.Number = repo.Counter
build.Created = time.Now().UTC().Unix() build.Created = time.Now().UTC().Unix()
build.Enqueued = build.Created build.Enqueued = build.Created
// only Insert set auto created ID back to object // only Insert set auto created ID back to object

View file

@ -19,6 +19,7 @@ import (
"testing" "testing"
"github.com/franela/goblin" "github.com/franela/goblin"
"github.com/stretchr/testify/assert"
"github.com/woodpecker-ci/woodpecker/server/model" "github.com/woodpecker-ci/woodpecker/server/model"
) )
@ -287,34 +288,20 @@ func TestBuilds(t *testing.T) {
} }
func TestBuildIncrement(t *testing.T) { func TestBuildIncrement(t *testing.T) {
store, closer := newTestStore(t, new(model.Build), new(model.Repo)) store, closer := newTestStore(t, new(model.Build))
defer closer() defer closer()
repo := &model.Repo{ buildA := &model.Build{RepoID: 1}
UserID: 1, if !assert.NoError(t, store.CreateBuild(buildA)) {
FullName: "bradrydzewski/test", return
Owner: "bradrydzewski",
Name: "test",
}
if err := store.CreateRepo(repo); err != nil {
t.Error(err)
} }
assert.EqualValues(t, 1, buildA.Number)
if err := store.CreateBuild(&model.Build{RepoID: repo.ID}); err != nil { buildB := &model.Build{RepoID: 1}
t.Error(err) assert.NoError(t, store.CreateBuild(buildB))
} assert.EqualValues(t, 2, buildB.Number)
repo, _ = store.GetRepo(repo.ID)
if got, want := repo.Counter, int64(1); got != want { buildC := &model.Build{RepoID: 2}
t.Errorf("Want repository counter incremented to %d, got %d", want, got) assert.NoError(t, store.CreateBuild(buildC))
} assert.EqualValues(t, 1, buildC.Number)
if err := store.CreateBuild(&model.Build{RepoID: repo.ID}); err != nil {
t.Error(err)
}
repo, _ = store.GetRepo(repo.ID)
if got, want := repo.Counter, int64(2); got != want {
t.Errorf("Want repository counter incremented to %d, got %d", want, got)
}
} }

View file

@ -0,0 +1,26 @@
// Copyright 2021 Woodpecker Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package migration
import (
"xorm.io/xorm"
)
var alterTableReposDropCounter = task{
name: "alter-table-drop-counter",
fn: func(sess *xorm.Session) error {
return dropTableColumns(sess, "repos", "repo_counter")
},
}

View file

@ -31,6 +31,7 @@ var migrationTasks = []task{
alterTableReposDropFallback, alterTableReposDropFallback,
alterTableReposDropAllowDeploysAllowTags, alterTableReposDropAllowDeploysAllowTags,
fixPRSecretEventName, fixPRSecretEventName,
alterTableReposDropCounter,
} }
type migrations struct { type migrations struct {