4de909747b
go-require lint is ignored for now Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/4535 Reviewed-by: Gusted <gusted@noreply.codeberg.org> Co-authored-by: TheFox0x7 <thefox0x7@gmail.com> Co-committed-by: TheFox0x7 <thefox0x7@gmail.com>
47 lines
1.2 KiB
Go
47 lines
1.2 KiB
Go
// SPDX-License-Identifier: MIT
|
|
|
|
package semver
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"code.gitea.io/gitea/models/db"
|
|
"code.gitea.io/gitea/models/unittest"
|
|
|
|
"github.com/hashicorp/go-version"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestForgejoSemVerSetGet(t *testing.T) {
|
|
require.NoError(t, unittest.PrepareTestDatabase())
|
|
ctx := db.DefaultContext
|
|
|
|
newVersion, err := version.NewVersion("v1.2.3")
|
|
require.NoError(t, err)
|
|
require.NoError(t, SetVersionString(ctx, newVersion.String()))
|
|
databaseVersion, err := GetVersion(ctx)
|
|
require.NoError(t, err)
|
|
assert.EqualValues(t, newVersion.String(), databaseVersion.String())
|
|
assert.True(t, newVersion.Equal(databaseVersion))
|
|
}
|
|
|
|
func TestForgejoSemVerMissing(t *testing.T) {
|
|
require.NoError(t, unittest.PrepareTestDatabase())
|
|
ctx := db.DefaultContext
|
|
e := db.GetEngine(ctx)
|
|
|
|
_, err := e.Exec("delete from forgejo_sem_ver")
|
|
require.NoError(t, err)
|
|
|
|
v, err := GetVersion(ctx)
|
|
require.NoError(t, err)
|
|
assert.EqualValues(t, "1.0.0", v.String())
|
|
|
|
_, err = e.Exec("drop table forgejo_sem_ver")
|
|
require.NoError(t, err)
|
|
|
|
v, err = GetVersion(ctx)
|
|
require.NoError(t, err)
|
|
assert.EqualValues(t, "1.0.0", v.String())
|
|
}
|