Skip to content

Commit

Permalink
Update test to handle new StepResult structs
Browse files Browse the repository at this point in the history
Signed-off-by: John Kjell <[email protected]>
  • Loading branch information
jkjell committed Oct 10, 2024
1 parent 8ae13c2 commit 5bb1527
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 8 deletions.
11 changes: 4 additions & 7 deletions policy/policy.go
Original file line number Diff line number Diff line change
Expand Up @@ -252,9 +252,7 @@ func (p Policy) Verify(ctx context.Context, opts ...VerifyOption) (bool, map[str
// Verify the functionaries
functionaryCheckResults := step.checkFunctionaries(collections, trustBundles)
stepResult := step.validateAttestations(functionaryCheckResults.Passed)
for _, functionaryReject := range functionaryCheckResults.Rejected {
stepResult.Rejected = append(stepResult.Rejected, functionaryReject)
}
stepResult.Rejected = append(stepResult.Rejected, functionaryCheckResults.Rejected...)

// We perform many searches against the same step, so we need to merge the relevant fields
if resultsByStep[stepName].Step == "" {
Expand Down Expand Up @@ -316,13 +314,12 @@ func (step Step) checkFunctionaries(statements []source.CollectionVerificationRe
}

if len(statements[i].ValidFunctionaries) == 0 {
result.Rejected = append(result.Rejected, RejectedCollection{Collection: statement, Reason: fmt.Errorf("no verifiers matched with allowed functionaries for step %s", step.Name)})
result.Rejected = append(result.Rejected, RejectedCollection{Collection: statements[i], Reason: fmt.Errorf("no verifiers matched with allowed functionaries for step %s", step.Name)})
} else {
result.Passed = append(result.Passed, statement)
result.Passed = append(result.Passed, statements[i])
}
} else {
statements[i].Errors = append(statement.Errors)
result.Rejected = append(result.Rejected, RejectedCollection{Collection: statement, Reason: fmt.Errorf("no verifiers present to validate against collection verifiers")})
result.Rejected = append(result.Rejected, RejectedCollection{Collection: statements[i], Reason: fmt.Errorf("no verifiers present to validate against collection verifiers")})
}
}

Expand Down
11 changes: 10 additions & 1 deletion policy/policy_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -588,7 +588,7 @@ func TestCheckFunctionaries(t *testing.T) {
fmt.Println("running test case: ", testCase.name)
result := testCase.step.checkFunctionaries(testCase.statements, testCase.trustBundles)
resultCheckFields := []source.CollectionVerificationResult{}
for _, r := range result {
for _, r := range result.Passed {
o := source.CollectionVerificationResult{
Errors: r.Errors,
Warnings: r.Warnings,
Expand All @@ -597,6 +597,15 @@ func TestCheckFunctionaries(t *testing.T) {
resultCheckFields = append(resultCheckFields, o)
}

for _, r := range result.Rejected {
o := source.CollectionVerificationResult{
Errors: r.Collection.Errors,
Warnings: r.Collection.Warnings,
ValidFunctionaries: r.Collection.ValidFunctionaries,
}
resultCheckFields = append(resultCheckFields, o)
}

assert.Equal(t, testCase.expectedResults, resultCheckFields)
}
}

0 comments on commit 5bb1527

Please sign in to comment.