2022-10-24 13:29:24 +05:30
|
|
|
// Copyright 2022 The Gitea Authors. All rights reserved.
|
2022-11-27 23:50:29 +05:30
|
|
|
// SPDX-License-Identifier: MIT
|
2022-10-24 13:29:24 +05:30
|
|
|
|
2022-11-02 14:24:36 +05:30
|
|
|
package v1_18 //nolint
|
2022-10-24 13:29:24 +05:30
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2024-07-14 19:04:42 +05:30
|
|
|
migration_tests "code.gitea.io/gitea/models/migrations/test"
|
2022-11-02 14:24:36 +05:30
|
|
|
|
2022-10-24 13:29:24 +05:30
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2022-11-02 14:24:36 +05:30
|
|
|
func Test_AddConfidentialClientColumnToOAuth2ApplicationTable(t *testing.T) {
|
2022-10-24 13:29:24 +05:30
|
|
|
// premigration
|
2024-04-23 08:30:57 +05:30
|
|
|
type oauth2Application struct {
|
2022-10-24 13:29:24 +05:30
|
|
|
ID int64
|
|
|
|
}
|
|
|
|
|
|
|
|
// Prepare and load the testing database
|
2024-07-14 19:04:42 +05:30
|
|
|
x, deferable := migration_tests.PrepareTestEnv(t, 0, new(oauth2Application))
|
2022-10-24 13:29:24 +05:30
|
|
|
defer deferable()
|
|
|
|
if x == nil || t.Failed() {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-11-02 14:24:36 +05:30
|
|
|
if err := AddConfidentialClientColumnToOAuth2ApplicationTable(x); err != nil {
|
2022-10-24 13:29:24 +05:30
|
|
|
assert.NoError(t, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// postmigration
|
|
|
|
type ExpectedOAuth2Application struct {
|
|
|
|
ID int64
|
|
|
|
ConfidentialClient bool
|
|
|
|
}
|
|
|
|
|
|
|
|
got := []ExpectedOAuth2Application{}
|
2024-04-23 08:30:57 +05:30
|
|
|
if err := x.Table("oauth2_application").Select("id, confidential_client").Find(&got); !assert.NoError(t, err) {
|
2022-10-24 13:29:24 +05:30
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.NotEmpty(t, got)
|
|
|
|
for _, e := range got {
|
|
|
|
assert.True(t, e.ConfidentialClient)
|
|
|
|
}
|
|
|
|
}
|