mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-04-26 13:40:20 +03:00

Some checks are pending
/ release (push) Waiting to run
testing / test-unit (push) Blocked by required conditions
testing / backend-checks (push) Waiting to run
testing / frontend-checks (push) Waiting to run
testing / test-e2e (push) Blocked by required conditions
testing / test-remote-cacher (redis) (push) Blocked by required conditions
testing / test-remote-cacher (valkey) (push) Blocked by required conditions
testing / test-remote-cacher (garnet) (push) Blocked by required conditions
testing / test-remote-cacher (redict) (push) Blocked by required conditions
testing / test-mysql (push) Blocked by required conditions
testing / test-pgsql (push) Blocked by required conditions
testing / test-sqlite (push) Blocked by required conditions
testing / security-check (push) Blocked by required conditions
The only parameter that is ever used is a single directory, make it that only instead of a more complex option structure. Remove tests.AddFixtures that was the simpler form because it is now redundant. --- Backporting to v11.0 will help with automated backporting of bug fixes in need of custom made fixtures. Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/7648 Reviewed-by: Michael Kriese <michael.kriese@gmx.de> Co-authored-by: Earl Warren <contact@earl-warren.org> Co-committed-by: Earl Warren <contact@earl-warren.org>
95 lines
2.9 KiB
Go
95 lines
2.9 KiB
Go
// Copyright 2024 The Forgejo Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package git
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"forgejo.org/models/db"
|
|
"forgejo.org/models/unittest"
|
|
"forgejo.org/modules/setting"
|
|
"forgejo.org/modules/test"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestIterateRepositoryIDsWithLFSMetaObjects(t *testing.T) {
|
|
defer unittest.OverrideFixtures("models/git/TestIterateRepositoryIDsWithLFSMetaObjects")()
|
|
require.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
type repocount struct {
|
|
repoid int64
|
|
count int64
|
|
}
|
|
expected := []repocount{{1, 1}, {54, 4}}
|
|
|
|
t.Run("Normal batch size", func(t *testing.T) {
|
|
defer test.MockVariableValue(&setting.Database.IterateBufferSize, 20)()
|
|
cases := []repocount{}
|
|
|
|
err := IterateRepositoryIDsWithLFSMetaObjects(db.DefaultContext, func(ctx context.Context, repoID, count int64) error {
|
|
cases = append(cases, repocount{repoID, count})
|
|
return nil
|
|
})
|
|
require.NoError(t, err)
|
|
assert.Equal(t, expected, cases)
|
|
})
|
|
|
|
t.Run("Low batch size", func(t *testing.T) {
|
|
defer test.MockVariableValue(&setting.Database.IterateBufferSize, 1)()
|
|
cases := []repocount{}
|
|
|
|
err := IterateRepositoryIDsWithLFSMetaObjects(db.DefaultContext, func(ctx context.Context, repoID, count int64) error {
|
|
cases = append(cases, repocount{repoID, count})
|
|
return nil
|
|
})
|
|
require.NoError(t, err)
|
|
assert.Equal(t, expected, cases)
|
|
})
|
|
}
|
|
|
|
func TestIterateLFSMetaObjectsForRepo(t *testing.T) {
|
|
require.NoError(t, unittest.PrepareTestDatabase())
|
|
|
|
expectedIDs := []int64{1, 2, 3, 4}
|
|
|
|
t.Run("Normal batch size", func(t *testing.T) {
|
|
defer test.MockVariableValue(&setting.Database.IterateBufferSize, 20)()
|
|
actualIDs := []int64{}
|
|
|
|
err := IterateLFSMetaObjectsForRepo(db.DefaultContext, 54, func(ctx context.Context, lo *LFSMetaObject) error {
|
|
actualIDs = append(actualIDs, lo.ID)
|
|
return nil
|
|
}, &IterateLFSMetaObjectsForRepoOptions{})
|
|
require.NoError(t, err)
|
|
assert.Equal(t, expectedIDs, actualIDs)
|
|
})
|
|
|
|
t.Run("Low batch size", func(t *testing.T) {
|
|
defer test.MockVariableValue(&setting.Database.IterateBufferSize, 1)()
|
|
actualIDs := []int64{}
|
|
|
|
err := IterateLFSMetaObjectsForRepo(db.DefaultContext, 54, func(ctx context.Context, lo *LFSMetaObject) error {
|
|
actualIDs = append(actualIDs, lo.ID)
|
|
return nil
|
|
}, &IterateLFSMetaObjectsForRepoOptions{})
|
|
require.NoError(t, err)
|
|
assert.Equal(t, expectedIDs, actualIDs)
|
|
|
|
t.Run("Batch handles updates", func(t *testing.T) {
|
|
actualIDs := []int64{}
|
|
|
|
err := IterateLFSMetaObjectsForRepo(db.DefaultContext, 54, func(ctx context.Context, lo *LFSMetaObject) error {
|
|
actualIDs = append(actualIDs, lo.ID)
|
|
_, err := db.DeleteByID[LFSMetaObject](ctx, lo.ID)
|
|
require.NoError(t, err)
|
|
return nil
|
|
}, &IterateLFSMetaObjectsForRepoOptions{})
|
|
require.NoError(t, err)
|
|
assert.Equal(t, expectedIDs, actualIDs)
|
|
})
|
|
})
|
|
}
|