 2457f5ff22
			
		
	
	
	2457f5ff22
	
	
	
		
			
			- Massive replacement of changing `code.gitea.io/gitea` to `forgejo.org`. - Resolves forgejo/discussions#258 Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/7337 Reviewed-by: Earl Warren <earl-warren@noreply.codeberg.org> Reviewed-by: Michael Kriese <michael.kriese@gmx.de> Reviewed-by: Beowulf <beowulf@beocode.eu> Reviewed-by: Panagiotis "Ivory" Vasilopoulos <git@n0toose.net> Co-authored-by: Gusted <postmaster@gusted.xyz> Co-committed-by: Gusted <postmaster@gusted.xyz>
		
			
				
	
	
		
			74 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2023 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package repository_test
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"testing"
 | |
| 	"time"
 | |
| 
 | |
| 	"forgejo.org/models/db"
 | |
| 	git_model "forgejo.org/models/git"
 | |
| 	repo_model "forgejo.org/models/repo"
 | |
| 	"forgejo.org/models/unittest"
 | |
| 	"forgejo.org/modules/lfs"
 | |
| 	"forgejo.org/modules/setting"
 | |
| 	"forgejo.org/modules/storage"
 | |
| 	repo_service "forgejo.org/services/repository"
 | |
| 
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| 	"github.com/stretchr/testify/require"
 | |
| )
 | |
| 
 | |
| func TestGarbageCollectLFSMetaObjects(t *testing.T) {
 | |
| 	unittest.PrepareTestEnv(t)
 | |
| 
 | |
| 	setting.LFS.StartServer = true
 | |
| 	err := storage.Init()
 | |
| 	require.NoError(t, err)
 | |
| 
 | |
| 	repo, err := repo_model.GetRepositoryByOwnerAndName(db.DefaultContext, "user2", "lfs")
 | |
| 	require.NoError(t, err)
 | |
| 
 | |
| 	validLFSObjects, err := db.GetEngine(db.DefaultContext).Count(git_model.LFSMetaObject{RepositoryID: repo.ID})
 | |
| 	require.NoError(t, err)
 | |
| 	assert.Greater(t, validLFSObjects, int64(1))
 | |
| 
 | |
| 	// add lfs object
 | |
| 	lfsContent := []byte("gitea1")
 | |
| 	lfsOid := storeObjectInRepo(t, repo.ID, &lfsContent)
 | |
| 
 | |
| 	// gc
 | |
| 	err = repo_service.GarbageCollectLFSMetaObjects(t.Context(), repo_service.GarbageCollectLFSMetaObjectsOptions{
 | |
| 		AutoFix:                 true,
 | |
| 		OlderThan:               time.Now().Add(7 * 24 * time.Hour).Add(5 * 24 * time.Hour),
 | |
| 		UpdatedLessRecentlyThan: time.Time{}, // ensure that the models/fixtures/lfs_meta_object.yml objects are considered as well
 | |
| 		LogDetail:               t.Logf,
 | |
| 	})
 | |
| 	require.NoError(t, err)
 | |
| 
 | |
| 	// lfs meta has been deleted
 | |
| 	_, err = git_model.GetLFSMetaObjectByOid(db.DefaultContext, repo.ID, lfsOid)
 | |
| 	require.ErrorIs(t, err, git_model.ErrLFSObjectNotExist)
 | |
| 
 | |
| 	remainingLFSObjects, err := db.GetEngine(db.DefaultContext).Count(git_model.LFSMetaObject{RepositoryID: repo.ID})
 | |
| 	require.NoError(t, err)
 | |
| 	assert.Equal(t, validLFSObjects-1, remainingLFSObjects)
 | |
| }
 | |
| 
 | |
| func storeObjectInRepo(t *testing.T, repositoryID int64, content *[]byte) string {
 | |
| 	pointer, err := lfs.GeneratePointer(bytes.NewReader(*content))
 | |
| 	require.NoError(t, err)
 | |
| 
 | |
| 	_, err = git_model.NewLFSMetaObject(db.DefaultContext, repositoryID, pointer)
 | |
| 	require.NoError(t, err)
 | |
| 	contentStore := lfs.NewContentStore()
 | |
| 	exist, err := contentStore.Exists(pointer)
 | |
| 	require.NoError(t, err)
 | |
| 	if !exist {
 | |
| 		err := contentStore.Put(pointer, bytes.NewReader(*content))
 | |
| 		require.NoError(t, err)
 | |
| 	}
 | |
| 	return pointer.Oid
 | |
| }
 |