add extra resiliency to snapshot restore test (#16712)

pull/16728/head
Dhia Ayachi 2023-03-21 14:27:00 -04:00 committed by GitHub
parent 8f7e4d4a7c
commit 769d9505a8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 15 additions and 0 deletions

View File

@ -3,6 +3,7 @@ package snapshot
import ( import (
"fmt" "fmt"
"github.com/hashicorp/consul/api" "github.com/hashicorp/consul/api"
"github.com/hashicorp/consul/sdk/testutil/retry"
libcluster "github.com/hashicorp/consul/test/integration/consul-container/libs/cluster" libcluster "github.com/hashicorp/consul/test/integration/consul-container/libs/cluster"
libtopology "github.com/hashicorp/consul/test/integration/consul-container/libs/topology" libtopology "github.com/hashicorp/consul/test/integration/consul-container/libs/topology"
"github.com/hashicorp/consul/test/integration/consul-container/libs/utils" "github.com/hashicorp/consul/test/integration/consul-container/libs/utils"
@ -79,6 +80,9 @@ func testSnapShotRestoreForLogStore(t *testing.T, logStore libcluster.LogStore)
libcluster.WaitForLeader(t, cluster2, client2) libcluster.WaitForLeader(t, cluster2, client2)
leader, err := cluster2.Leader()
require.NoError(t, err)
followers, err := cluster2.Followers() followers, err := cluster2.Followers()
require.NoError(t, err) require.NoError(t, err)
require.Len(t, followers, 2) require.Len(t, followers, 2)
@ -86,6 +90,17 @@ func testSnapShotRestoreForLogStore(t *testing.T, logStore libcluster.LogStore)
// use a follower api client and set `AllowStale` to true // use a follower api client and set `AllowStale` to true
// to test the follower snapshot install code path as well. // to test the follower snapshot install code path as well.
fc := followers[0].GetClient() fc := followers[0].GetClient()
lc := leader.GetClient()
retry.Run(t, func(r *retry.R) {
self, err := lc.Agent().Self()
require.NoError(r, err)
LeaderLogIndex := self["Stats"]["raft"].(map[string]interface{})["last_log_index"].(string)
self, err = fc.Agent().Self()
require.NoError(r, err)
followerLogIndex := self["Stats"]["raft"].(map[string]interface{})["last_log_index"].(string)
require.Equal(r, LeaderLogIndex, followerLogIndex)
})
for i := 0; i < 100; i++ { for i := 0; i < 100; i++ {
kv, _, err := fc.KV().Get(fmt.Sprintf("key-%d", i), &api.QueryOptions{AllowStale: true}) kv, _, err := fc.KV().Get(fmt.Sprintf("key-%d", i), &api.QueryOptions{AllowStale: true})