forked from archway-network/valuter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
performance-test.go
108 lines (82 loc) · 2.79 KB
/
performance-test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
package tasks
import (
"sort"
"github.com/celestiaorg/valuter/configs"
"github.com/celestiaorg/valuter/participants"
"github.com/celestiaorg/valuter/validators"
"github.com/celestiaorg/valuter/winners"
)
func GetPerformanceTestWinners() (winners.WinnersList, error) {
var winnersList winners.WinnersList
for i := range configs.Configs.Tasks.UpTime.Conditions {
roundWinnerList, err := GetPerformanceTestWinnersPerLoadBurst(i)
if err != nil {
return winnersList, err
}
winnersList.MergeWithAggregateRewards(roundWinnerList)
}
return winnersList, nil
}
// This function receives a load index which is just the index in the config file
// for the load burst which starts from zero
func GetPerformanceTestWinnersPerLoadBurst(loadIndex int) (winners.WinnersList, error) {
var winnersList winners.WinnersList
if configs.Configs.Tasks.UpTime.MaxWinners == 0 {
return winnersList, nil
}
listOfValidators, err := GetValidatorsSortedByUpTimeInBlockHeightRange(
configs.Configs.Tasks.UpTime.Conditions[loadIndex].StartHight,
configs.Configs.Tasks.UpTime.Conditions[loadIndex].EndHight,
)
if err != nil {
return winnersList, err
}
for i := range listOfValidators {
// Filter out those who could not maintaine the required uptime
if listOfValidators[i].UpTime < configs.Configs.Tasks.UpTime.Conditions[loadIndex].UptimePercent {
continue
}
valInfo, err := listOfValidators[i].GetValidatorInfo()
if err != nil {
return winnersList, err
}
pRecord, err := participants.GetParticipantByAddress(listOfValidators[i].AccAddr)
if err != nil {
return winnersList, err
}
// If the participant is not verified by KYC provider, just ignore it
if !pRecord.KycVerified {
continue
}
newWinner := winners.Winner{
Address: listOfValidators[i].AccAddr,
Rewards: configs.Configs.Tasks.UpTime.Reward,
ValidatorInfo: valInfo,
ParticipantData: pRecord,
}
winnersList.Append(newWinner)
if winnersList.Length() >= configs.Configs.Tasks.UpTime.MaxWinners {
break // Max winners reached
}
}
return winnersList, nil
}
func GetValidatorsSortedByUpTimeInBlockHeightRange(beginHeight, endHeight uint64) ([]validators.ValidatorInfo, error) {
listOfValidators, err := validators.GetAllValidators()
if err != nil {
return nil, err
}
// get validators info which includes uptime in the given range
var listOfValidatorsInfo []validators.ValidatorInfo
for i := range listOfValidators {
vInfo, err := listOfValidators[i].GetValidatorInfoByBlockHeightRange(beginHeight, endHeight)
if err != nil {
return nil, err
}
listOfValidatorsInfo = append(listOfValidatorsInfo, vInfo)
}
sort.Slice(listOfValidatorsInfo, func(i, j int) bool {
return listOfValidatorsInfo[i].UpTime > listOfValidatorsInfo[j].UpTime
})
return listOfValidatorsInfo, nil
}