2023-06-13 23:42:38 -04:00
|
|
|
// Copyright 2023 The Gitea Authors. All rights reserved.
|
|
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
|
|
|
|
package setting
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2024-07-30 15:41:10 -04:00
|
|
|
"github.com/stretchr/testify/require"
|
2023-06-13 23:42:38 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
func Test_getStorageInheritNameSectionTypeForLFS(t *testing.T) {
|
|
|
|
iniStr := `
|
|
|
|
[storage]
|
|
|
|
STORAGE_TYPE = minio
|
|
|
|
`
|
|
|
|
cfg, err := NewConfigProviderFromData(iniStr)
|
2024-07-30 15:41:10 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NoError(t, loadLFSFrom(cfg))
|
2023-06-13 23:42:38 -04:00
|
|
|
|
|
|
|
assert.EqualValues(t, "minio", LFS.Storage.Type)
|
|
|
|
assert.EqualValues(t, "lfs/", LFS.Storage.MinioConfig.BasePath)
|
|
|
|
|
2023-07-25 23:53:37 -04:00
|
|
|
iniStr = `
|
|
|
|
[server]
|
|
|
|
LFS_CONTENT_PATH = path_ignored
|
|
|
|
[lfs]
|
|
|
|
PATH = path_used
|
|
|
|
`
|
|
|
|
cfg, err = NewConfigProviderFromData(iniStr)
|
2024-07-30 15:41:10 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NoError(t, loadLFSFrom(cfg))
|
2023-07-25 23:53:37 -04:00
|
|
|
|
|
|
|
assert.EqualValues(t, "local", LFS.Storage.Type)
|
|
|
|
assert.Contains(t, LFS.Storage.Path, "path_used")
|
|
|
|
|
|
|
|
iniStr = `
|
|
|
|
[server]
|
|
|
|
LFS_CONTENT_PATH = deprecatedpath
|
|
|
|
`
|
|
|
|
cfg, err = NewConfigProviderFromData(iniStr)
|
2024-07-30 15:41:10 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NoError(t, loadLFSFrom(cfg))
|
2023-07-25 23:53:37 -04:00
|
|
|
|
|
|
|
assert.EqualValues(t, "local", LFS.Storage.Type)
|
|
|
|
assert.Contains(t, LFS.Storage.Path, "deprecatedpath")
|
|
|
|
|
2023-06-13 23:42:38 -04:00
|
|
|
iniStr = `
|
|
|
|
[storage.lfs]
|
|
|
|
STORAGE_TYPE = minio
|
|
|
|
`
|
|
|
|
cfg, err = NewConfigProviderFromData(iniStr)
|
2024-07-30 15:41:10 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NoError(t, loadLFSFrom(cfg))
|
2023-06-13 23:42:38 -04:00
|
|
|
|
|
|
|
assert.EqualValues(t, "minio", LFS.Storage.Type)
|
|
|
|
assert.EqualValues(t, "lfs/", LFS.Storage.MinioConfig.BasePath)
|
|
|
|
|
|
|
|
iniStr = `
|
|
|
|
[lfs]
|
|
|
|
STORAGE_TYPE = my_minio
|
|
|
|
|
|
|
|
[storage.my_minio]
|
|
|
|
STORAGE_TYPE = minio
|
|
|
|
`
|
|
|
|
cfg, err = NewConfigProviderFromData(iniStr)
|
2024-07-30 15:41:10 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NoError(t, loadLFSFrom(cfg))
|
2023-06-13 23:42:38 -04:00
|
|
|
|
|
|
|
assert.EqualValues(t, "minio", LFS.Storage.Type)
|
|
|
|
assert.EqualValues(t, "lfs/", LFS.Storage.MinioConfig.BasePath)
|
|
|
|
|
|
|
|
iniStr = `
|
|
|
|
[lfs]
|
|
|
|
STORAGE_TYPE = my_minio
|
|
|
|
MINIO_BASE_PATH = my_lfs/
|
|
|
|
|
|
|
|
[storage.my_minio]
|
|
|
|
STORAGE_TYPE = minio
|
|
|
|
`
|
|
|
|
cfg, err = NewConfigProviderFromData(iniStr)
|
2024-07-30 15:41:10 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.NoError(t, loadLFSFrom(cfg))
|
2023-06-13 23:42:38 -04:00
|
|
|
|
|
|
|
assert.EqualValues(t, "minio", LFS.Storage.Type)
|
|
|
|
assert.EqualValues(t, "my_lfs/", LFS.Storage.MinioConfig.BasePath)
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_LFSStorage1(t *testing.T) {
|
|
|
|
iniStr := `
|
|
|
|
[storage]
|
|
|
|
STORAGE_TYPE = minio
|
|
|
|
`
|
|
|
|
cfg, err := NewConfigProviderFromData(iniStr)
|
2024-07-30 15:41:10 -04:00
|
|
|
require.NoError(t, err)
|
2023-06-13 23:42:38 -04:00
|
|
|
|
2024-07-30 15:41:10 -04:00
|
|
|
require.NoError(t, loadLFSFrom(cfg))
|
2023-06-13 23:42:38 -04:00
|
|
|
assert.EqualValues(t, "minio", LFS.Storage.Type)
|
|
|
|
assert.EqualValues(t, "gitea", LFS.Storage.MinioConfig.Bucket)
|
|
|
|
assert.EqualValues(t, "lfs/", LFS.Storage.MinioConfig.BasePath)
|
|
|
|
}
|
2024-10-30 01:41:55 -04:00
|
|
|
|
|
|
|
func Test_LFSClientServerConfigs(t *testing.T) {
|
|
|
|
iniStr := `
|
|
|
|
[server]
|
|
|
|
LFS_MAX_BATCH_SIZE = 100
|
|
|
|
[lfs_client]
|
|
|
|
# will default to 20
|
|
|
|
BATCH_SIZE = 0
|
|
|
|
`
|
|
|
|
cfg, err := NewConfigProviderFromData(iniStr)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
assert.NoError(t, loadLFSFrom(cfg))
|
|
|
|
assert.EqualValues(t, 100, LFS.MaxBatchSize)
|
|
|
|
assert.EqualValues(t, 20, LFSClient.BatchSize)
|
2024-11-05 08:10:57 -05:00
|
|
|
assert.EqualValues(t, 8, LFSClient.BatchOperationConcurrency)
|
2024-11-03 23:49:08 -05:00
|
|
|
|
|
|
|
iniStr = `
|
|
|
|
[lfs_client]
|
|
|
|
BATCH_SIZE = 50
|
|
|
|
BATCH_OPERATION_CONCURRENCY = 10
|
|
|
|
`
|
|
|
|
cfg, err = NewConfigProviderFromData(iniStr)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
assert.NoError(t, loadLFSFrom(cfg))
|
|
|
|
assert.EqualValues(t, 50, LFSClient.BatchSize)
|
|
|
|
assert.EqualValues(t, 10, LFSClient.BatchOperationConcurrency)
|
2024-10-30 01:41:55 -04:00
|
|
|
}
|