mirror of
https://github.com/go-gitea/gitea
synced 2024-10-31 23:34:25 +00:00
efd34d0d7d
Backport #19225 Backport #19229 The RepoIndexerTest is failing with considerable frequency due to a race inherrent in its design. This PR adjust this test to avoid the reliance on waiting for the populate repo indexer to run and forcibly adds the repo to the queue. It then flushes the queue. It may be worth separating out the tests somewhat by testing the Index function directly away from the queue however, this forceful method should solve the current problem. Fix #19162 Signed-off-by: Andrew Thornton <art27@cantab.net>
57 lines
1.3 KiB
Go
57 lines
1.3 KiB
Go
// Copyright 2020 The Gitea Authors. All rights reserved.
|
|
// Use of this source code is governed by a MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package stats
|
|
|
|
import (
|
|
"context"
|
|
"path/filepath"
|
|
"testing"
|
|
"time"
|
|
|
|
repo_model "code.gitea.io/gitea/models/repo"
|
|
"code.gitea.io/gitea/models/unittest"
|
|
"code.gitea.io/gitea/modules/git"
|
|
"code.gitea.io/gitea/modules/queue"
|
|
"code.gitea.io/gitea/modules/setting"
|
|
|
|
_ "code.gitea.io/gitea/models"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"gopkg.in/ini.v1"
|
|
)
|
|
|
|
func TestMain(m *testing.M) {
|
|
unittest.MainTest(m, filepath.Join("..", "..", ".."))
|
|
}
|
|
|
|
func TestRepoStatsIndex(t *testing.T) {
|
|
if err := git.Init(context.Background()); !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
|
setting.Cfg = ini.Empty()
|
|
|
|
setting.NewQueueService()
|
|
|
|
err := Init()
|
|
assert.NoError(t, err)
|
|
|
|
repo, err := repo_model.GetRepositoryByID(1)
|
|
assert.NoError(t, err)
|
|
|
|
err = UpdateRepoIndexer(repo)
|
|
assert.NoError(t, err)
|
|
|
|
queue.GetManager().FlushAll(context.Background(), 5*time.Second)
|
|
|
|
status, err := repo_model.GetIndexerStatus(repo, repo_model.RepoIndexerTypeStats)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, "65f1bf27bc3bf70f64657658635e66094edbcb4d", status.CommitSha)
|
|
langs, err := repo_model.GetTopLanguageStats(repo, 5)
|
|
assert.NoError(t, err)
|
|
assert.Empty(t, langs)
|
|
}
|