diff options
author | John Olheiser <42128690+jolheiser@users.noreply.github.com> | 2019-12-11 00:09:06 -0600 |
---|---|---|
committer | Lunny Xiao <xiaolunwen@gmail.com> | 2019-12-11 14:09:06 +0800 |
commit | 3bf5a07537a53c6903b39268559c5c76bee85c12 (patch) | |
tree | 0cd1f7602c09f4bf919a7fe87be84829bc5197c3 | |
parent | c3d31e55346329a221cc0ae37d89d1fba11ea737 (diff) | |
download | gitea-3bf5a07537a53c6903b39268559c5c76bee85c12.tar.gz gitea-3bf5a07537a53c6903b39268559c5c76bee85c12.zip |
Only sync tags after all batches (#9319)
Signed-off-by: jolheiser <john.olheiser@gmail.com>
-rw-r--r-- | modules/migrations/base/uploader.go | 2 | ||||
-rw-r--r-- | modules/migrations/gitea.go | 10 | ||||
-rw-r--r-- | modules/migrations/migrate.go | 10 |
3 files changed, 15 insertions, 7 deletions
diff --git a/modules/migrations/base/uploader.go b/modules/migrations/base/uploader.go index ae1be84b88..7d35d136a1 100644 --- a/modules/migrations/base/uploader.go +++ b/modules/migrations/base/uploader.go @@ -11,7 +11,7 @@ type Uploader interface { CreateRepo(repo *Repository, opts MigrateOptions) error CreateTopics(topic ...string) error CreateMilestones(milestones ...*Milestone) error - CreateReleases(releases ...*Release) error + CreateReleases(syncTags bool, releases ...*Release) error CreateLabels(labels ...*Label) error CreateIssues(issues ...*Issue) error CreateComments(comments ...*Comment) error diff --git a/modules/migrations/gitea.go b/modules/migrations/gitea.go index 81a6116a23..617561194d 100644 --- a/modules/migrations/gitea.go +++ b/modules/migrations/gitea.go @@ -201,7 +201,7 @@ func (g *GiteaLocalUploader) CreateLabels(labels ...*base.Label) error { } // CreateReleases creates releases -func (g *GiteaLocalUploader) CreateReleases(releases ...*base.Release) error { +func (g *GiteaLocalUploader) CreateReleases(syncTags bool, releases ...*base.Release) error { var rels = make([]*models.Release, 0, len(releases)) for _, release := range releases { var rel = models.Release{ @@ -292,8 +292,12 @@ func (g *GiteaLocalUploader) CreateReleases(releases ...*base.Release) error { return err } - // sync tags to releases in database - return models.SyncReleasesWithTags(g.repo, g.gitRepo) + if syncTags { + // sync tags to releases in database + return models.SyncReleasesWithTags(g.repo, g.gitRepo) + } + + return nil } // CreateIssues creates issues diff --git a/modules/migrations/migrate.go b/modules/migrations/migrate.go index cfaedf78e3..124ef4413f 100644 --- a/modules/migrations/migrate.go +++ b/modules/migrations/migrate.go @@ -161,12 +161,16 @@ func migrateRepository(downloader base.Downloader, uploader base.Uploader, opts } relBatchSize := uploader.MaxBatchInsertSize("release") + syncTags := false for len(releases) > 0 { - if len(releases) < relBatchSize { - relBatchSize = len(releases) + if len(releases) <= relBatchSize { + if len(releases) < relBatchSize { + relBatchSize = len(releases) + } + syncTags = true } - if err := uploader.CreateReleases(releases[:relBatchSize]...); err != nil { + if err := uploader.CreateReleases(syncTags, releases[:relBatchSize]...); err != nil { return err } releases = releases[relBatchSize:] |