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