]> source.dussan.org Git - gitea.git/commitdiff
Prevent intermittent failures in RepoIndexerTest (#19225 #19229) (#19228)
authorzeripath <art27@cantab.net>
Sun, 27 Mar 2022 23:01:53 +0000 (00:01 +0100)
committerGitHub <noreply@github.com>
Sun, 27 Mar 2022 23:01:53 +0000 (01:01 +0200)
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>
modules/indexer/stats/indexer_test.go

index 50c6cc38e9bbebb042b2062c6c6d608330e7e53c..b5c58ab25afabb0c292fe59b9a1457f64dffec98 100644 (file)
@@ -5,12 +5,15 @@
 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"
@@ -24,6 +27,10 @@ func TestMain(m *testing.M) {
 }
 
 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()
 
@@ -32,10 +39,14 @@ func TestRepoStatsIndex(t *testing.T) {
        err := Init()
        assert.NoError(t, err)
 
-       time.Sleep(5 * time.Second)
-
        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)