|  | # Copyright 2022 The BoringSSL Authors | 
|  | # | 
|  | # Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | # you may not use this file except in compliance with the License. | 
|  | # You may obtain a copy of the License at | 
|  | # | 
|  | #     https://www.apache.org/licenses/LICENSE-2.0 | 
|  | # | 
|  | # Unless required by applicable law or agreed to in writing, software | 
|  | # distributed under the License is distributed on an "AS IS" BASIS, | 
|  | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | # See the License for the specific language governing permissions and | 
|  | # limitations under the License. | 
|  |  | 
|  | # This script attempts to break each of the known KATs and checks that doing so | 
|  | # seems to work and at least mentions the correct KAT in the output. | 
|  |  | 
|  | set -x | 
|  | set -e | 
|  |  | 
|  | TEST_FIPS_BIN="build/test_fips" | 
|  |  | 
|  | if [ ! -f $TEST_FIPS_BIN ]; then | 
|  | echo "$TEST_FIPS_BIN is missing. Run this script from the top level of a" | 
|  | echo "BoringSSL checkout and ensure that ./build-fips-break-test-binaries.sh" | 
|  | echo "has been run first." | 
|  | exit 1 | 
|  | fi | 
|  |  | 
|  | KATS=$(go run util/fipstools/break-kat.go --list-tests) | 
|  |  | 
|  | for kat in $KATS; do | 
|  | go run util/fipstools/break-kat.go $TEST_FIPS_BIN $kat > break-kat-bin | 
|  | chmod u+x ./break-kat-bin | 
|  | if ! (./break-kat-bin 2>&1 >/dev/null || true) | \ | 
|  | egrep -q "^$kat[^a-zA-Z0-9]"; then | 
|  | echo "Failure for $kat did not mention that name in the output" | 
|  | exit 1 | 
|  | fi | 
|  | rm ./break-kat-bin | 
|  | done |