123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254 |
- // Copyright 2018 The Gitea Authors. All rights reserved.
- // Use of this source code is governed by a MIT-style
- // license that can be found in the LICENSE file.
-
- package release
-
- import (
- "path/filepath"
- "testing"
- "time"
-
- "code.gitea.io/gitea/models"
- "code.gitea.io/gitea/modules/git"
-
- "github.com/stretchr/testify/assert"
- )
-
- func TestMain(m *testing.M) {
- models.MainTest(m, filepath.Join("..", ".."))
- }
-
- func TestRelease_Create(t *testing.T) {
- assert.NoError(t, models.PrepareTestDatabase())
-
- user := models.AssertExistsAndLoadBean(t, &models.User{ID: 2}).(*models.User)
- repo := models.AssertExistsAndLoadBean(t, &models.Repository{ID: 1}).(*models.Repository)
- repoPath := models.RepoPath(user.Name, repo.Name)
-
- gitRepo, err := git.OpenRepository(repoPath)
- assert.NoError(t, err)
- defer gitRepo.Close()
-
- assert.NoError(t, CreateRelease(gitRepo, &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v0.1",
- Target: "master",
- Title: "v0.1 is released",
- Note: "v0.1 is released",
- IsDraft: false,
- IsPrerelease: false,
- IsTag: false,
- }, nil))
-
- assert.NoError(t, CreateRelease(gitRepo, &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v0.1.1",
- Target: "65f1bf27bc3bf70f64657658635e66094edbcb4d",
- Title: "v0.1.1 is released",
- Note: "v0.1.1 is released",
- IsDraft: false,
- IsPrerelease: false,
- IsTag: false,
- }, nil))
-
- assert.NoError(t, CreateRelease(gitRepo, &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v0.1.2",
- Target: "65f1bf2",
- Title: "v0.1.2 is released",
- Note: "v0.1.2 is released",
- IsDraft: false,
- IsPrerelease: false,
- IsTag: false,
- }, nil))
-
- assert.NoError(t, CreateRelease(gitRepo, &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v0.1.3",
- Target: "65f1bf2",
- Title: "v0.1.3 is released",
- Note: "v0.1.3 is released",
- IsDraft: true,
- IsPrerelease: false,
- IsTag: false,
- }, nil))
-
- assert.NoError(t, CreateRelease(gitRepo, &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v0.1.4",
- Target: "65f1bf2",
- Title: "v0.1.4 is released",
- Note: "v0.1.4 is released",
- IsDraft: false,
- IsPrerelease: true,
- IsTag: false,
- }, nil))
-
- assert.NoError(t, CreateRelease(gitRepo, &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v0.1.5",
- Target: "65f1bf2",
- Title: "v0.1.5 is released",
- Note: "v0.1.5 is released",
- IsDraft: false,
- IsPrerelease: false,
- IsTag: true,
- }, nil))
- }
-
- func TestRelease_Update(t *testing.T) {
- assert.NoError(t, models.PrepareTestDatabase())
-
- user := models.AssertExistsAndLoadBean(t, &models.User{ID: 2}).(*models.User)
- repo := models.AssertExistsAndLoadBean(t, &models.Repository{ID: 1}).(*models.Repository)
- repoPath := models.RepoPath(user.Name, repo.Name)
-
- gitRepo, err := git.OpenRepository(repoPath)
- assert.NoError(t, err)
- defer gitRepo.Close()
-
- // Test a changed release
- assert.NoError(t, CreateRelease(gitRepo, &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v1.1.1",
- Target: "master",
- Title: "v1.1.1 is released",
- Note: "v1.1.1 is released",
- IsDraft: false,
- IsPrerelease: false,
- IsTag: false,
- }, nil))
- release, err := models.GetRelease(repo.ID, "v1.1.1")
- assert.NoError(t, err)
- releaseCreatedUnix := release.CreatedUnix
- time.Sleep(2 * time.Second) // sleep 2 seconds to ensure a different timestamp
- release.Note = "Changed note"
- assert.NoError(t, UpdateRelease(user, gitRepo, release, nil))
- release, err = models.GetReleaseByID(release.ID)
- assert.NoError(t, err)
- assert.Equal(t, int64(releaseCreatedUnix), int64(release.CreatedUnix))
-
- // Test a changed draft
- assert.NoError(t, CreateRelease(gitRepo, &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v1.2.1",
- Target: "65f1bf2",
- Title: "v1.2.1 is draft",
- Note: "v1.2.1 is draft",
- IsDraft: true,
- IsPrerelease: false,
- IsTag: false,
- }, nil))
- release, err = models.GetRelease(repo.ID, "v1.2.1")
- assert.NoError(t, err)
- releaseCreatedUnix = release.CreatedUnix
- time.Sleep(2 * time.Second) // sleep 2 seconds to ensure a different timestamp
- release.Title = "Changed title"
- assert.NoError(t, UpdateRelease(user, gitRepo, release, nil))
- release, err = models.GetReleaseByID(release.ID)
- assert.NoError(t, err)
- assert.Less(t, int64(releaseCreatedUnix), int64(release.CreatedUnix))
-
- // Test a changed pre-release
- assert.NoError(t, CreateRelease(gitRepo, &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v1.3.1",
- Target: "65f1bf2",
- Title: "v1.3.1 is pre-released",
- Note: "v1.3.1 is pre-released",
- IsDraft: false,
- IsPrerelease: true,
- IsTag: false,
- }, nil))
- release, err = models.GetRelease(repo.ID, "v1.3.1")
- assert.NoError(t, err)
- releaseCreatedUnix = release.CreatedUnix
- time.Sleep(2 * time.Second) // sleep 2 seconds to ensure a different timestamp
- release.Title = "Changed title"
- release.Note = "Changed note"
- assert.NoError(t, UpdateRelease(user, gitRepo, release, nil))
- release, err = models.GetReleaseByID(release.ID)
- assert.NoError(t, err)
- assert.Equal(t, int64(releaseCreatedUnix), int64(release.CreatedUnix))
- }
-
- func TestRelease_createTag(t *testing.T) {
- assert.NoError(t, models.PrepareTestDatabase())
-
- user := models.AssertExistsAndLoadBean(t, &models.User{ID: 2}).(*models.User)
- repo := models.AssertExistsAndLoadBean(t, &models.Repository{ID: 1}).(*models.Repository)
- repoPath := models.RepoPath(user.Name, repo.Name)
-
- gitRepo, err := git.OpenRepository(repoPath)
- assert.NoError(t, err)
- defer gitRepo.Close()
-
- // Test a changed release
- release := &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v2.1.1",
- Target: "master",
- Title: "v2.1.1 is released",
- Note: "v2.1.1 is released",
- IsDraft: false,
- IsPrerelease: false,
- IsTag: false,
- }
- assert.NoError(t, createTag(gitRepo, release))
- assert.NotEmpty(t, release.CreatedUnix)
- releaseCreatedUnix := release.CreatedUnix
- time.Sleep(2 * time.Second) // sleep 2 seconds to ensure a different timestamp
- release.Note = "Changed note"
- assert.NoError(t, createTag(gitRepo, release))
- assert.Equal(t, int64(releaseCreatedUnix), int64(release.CreatedUnix))
-
- // Test a changed draft
- release = &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v2.2.1",
- Target: "65f1bf2",
- Title: "v2.2.1 is draft",
- Note: "v2.2.1 is draft",
- IsDraft: true,
- IsPrerelease: false,
- IsTag: false,
- }
- assert.NoError(t, createTag(gitRepo, release))
- releaseCreatedUnix = release.CreatedUnix
- time.Sleep(2 * time.Second) // sleep 2 seconds to ensure a different timestamp
- release.Title = "Changed title"
- assert.NoError(t, createTag(gitRepo, release))
- assert.Less(t, int64(releaseCreatedUnix), int64(release.CreatedUnix))
-
- // Test a changed pre-release
- release = &models.Release{
- RepoID: repo.ID,
- PublisherID: user.ID,
- TagName: "v2.3.1",
- Target: "65f1bf2",
- Title: "v2.3.1 is pre-released",
- Note: "v2.3.1 is pre-released",
- IsDraft: false,
- IsPrerelease: true,
- IsTag: false,
- }
- assert.NoError(t, createTag(gitRepo, release))
- releaseCreatedUnix = release.CreatedUnix
- time.Sleep(2 * time.Second) // sleep 2 seconds to ensure a different timestamp
- release.Title = "Changed title"
- release.Note = "Changed note"
- assert.NoError(t, createTag(gitRepo, release))
- assert.Equal(t, int64(releaseCreatedUnix), int64(release.CreatedUnix))
- }
|