@ -125,12 +125,61 @@ func (p *queryLogTest) query(t *testing.T) {
require . NoError ( t , err )
require . NoError ( t , err )
require . Equal ( t , 200 , r . StatusCode )
require . Equal ( t , 200 , r . StatusCode )
case ruleOrigin :
case ruleOrigin :
time . Sleep ( 2 * time . Second )
// Poll the /api/v1/rules endpoint until a new rule evaluation is detected.
var lastEvalTime time . Time
for {
r , err := http . Get ( fmt . Sprintf ( "http://%s:%d/api/v1/rules" , p . host , p . port ) )
require . NoError ( t , err )
rulesBody , err := io . ReadAll ( r . Body )
require . NoError ( t , err )
defer r . Body . Close ( )
// Parse the rules response to find the last evaluation time.
newEvalTime := parseLastEvaluation ( rulesBody )
if newEvalTime . After ( lastEvalTime ) {
if ! lastEvalTime . IsZero ( ) {
break
}
lastEvalTime = newEvalTime
}
time . Sleep ( 100 * time . Millisecond )
}
default :
default :
panic ( "can't query this origin" )
panic ( "can't query this origin" )
}
}
}
}
// parseLastEvaluation extracts the last evaluation timestamp from the /api/v1/rules response.
func parseLastEvaluation ( rulesBody [ ] byte ) time . Time {
var ruleResponse struct {
Status string ` json:"status" `
Data struct {
Groups [ ] struct {
Rules [ ] struct {
LastEvaluation string ` json:"lastEvaluation" `
} ` json:"rules" `
} ` json:"groups" `
} ` json:"data" `
}
err := json . Unmarshal ( rulesBody , & ruleResponse )
if err != nil {
return time . Time { }
}
for _ , group := range ruleResponse . Data . Groups {
for _ , rule := range group . Rules {
if evalTime , err := time . Parse ( time . RFC3339Nano , rule . LastEvaluation ) ; err == nil {
return evalTime
}
}
}
return time . Time { }
}
// queryString returns the expected queryString of a this test.
// queryString returns the expected queryString of a this test.
func ( p * queryLogTest ) queryString ( ) string {
func ( p * queryLogTest ) queryString ( ) string {
switch p . origin {
switch p . origin {
@ -322,7 +371,7 @@ func (p *queryLogTest) run(t *testing.T) {
if p . exactQueryCount ( ) {
if p . exactQueryCount ( ) {
require . Len ( t , ql , qc )
require . Len ( t , ql , qc )
} else {
} else {
require . Greater ( t , len ( ql ) , qc , "no queries logged" )
require . Greater OrEqual ( t , len ( ql ) , qc , "no queries logged" )
}
}
p . validateLastQuery ( t , ql )
p . validateLastQuery ( t , ql )
qc = len ( ql )
qc = len ( ql )
@ -353,7 +402,7 @@ func (p *queryLogTest) run(t *testing.T) {
if p . exactQueryCount ( ) {
if p . exactQueryCount ( ) {
require . Len ( t , ql , qc )
require . Len ( t , ql , qc )
} else {
} else {
require . Greater ( t , len ( ql ) , qc , "no queries logged" )
require . Greater OrEqual ( t , len ( ql ) , qc , "no queries logged" )
}
}
p . validateLastQuery ( t , ql )
p . validateLastQuery ( t , ql )