|  | // Copyright 2025 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. | 
|  |  | 
|  | package runner | 
|  |  | 
|  | func addPeekTests() { | 
|  | // Test SSL_peek works, including on empty records. | 
|  | testCases = append(testCases, testCase{ | 
|  | name:             "Peek-Basic", | 
|  | sendEmptyRecords: 1, | 
|  | flags:            []string{"-peek-then-read"}, | 
|  | }) | 
|  |  | 
|  | // Test SSL_peek can drive the initial handshake. | 
|  | testCases = append(testCases, testCase{ | 
|  | name: "Peek-ImplicitHandshake", | 
|  | flags: []string{ | 
|  | "-peek-then-read", | 
|  | "-implicit-handshake", | 
|  | }, | 
|  | }) | 
|  |  | 
|  | // Test SSL_peek can discover and drive a renegotiation. | 
|  | testCases = append(testCases, testCase{ | 
|  | name: "Peek-Renegotiate", | 
|  | config: Config{ | 
|  | MaxVersion: VersionTLS12, | 
|  | }, | 
|  | renegotiate: 1, | 
|  | flags: []string{ | 
|  | "-peek-then-read", | 
|  | "-renegotiate-freely", | 
|  | "-expect-total-renegotiations", "1", | 
|  | }, | 
|  | }) | 
|  |  | 
|  | // Test SSL_peek can discover a close_notify. | 
|  | testCases = append(testCases, testCase{ | 
|  | name: "Peek-Shutdown", | 
|  | config: Config{ | 
|  | Bugs: ProtocolBugs{ | 
|  | ExpectCloseNotify: true, | 
|  | }, | 
|  | }, | 
|  | flags: []string{ | 
|  | "-peek-then-read", | 
|  | "-check-close-notify", | 
|  | }, | 
|  | }) | 
|  |  | 
|  | // Test SSL_peek can discover an alert. | 
|  | testCases = append(testCases, testCase{ | 
|  | name: "Peek-Alert", | 
|  | config: Config{ | 
|  | Bugs: ProtocolBugs{ | 
|  | SendSpuriousAlert: alertRecordOverflow, | 
|  | }, | 
|  | }, | 
|  | flags:         []string{"-peek-then-read"}, | 
|  | shouldFail:    true, | 
|  | expectedError: ":TLSV1_ALERT_RECORD_OVERFLOW:", | 
|  | }) | 
|  |  | 
|  | // Test SSL_peek can handle KeyUpdate. | 
|  | testCases = append(testCases, testCase{ | 
|  | name: "Peek-KeyUpdate", | 
|  | config: Config{ | 
|  | MaxVersion: VersionTLS13, | 
|  | }, | 
|  | sendKeyUpdates:   1, | 
|  | keyUpdateRequest: keyUpdateNotRequested, | 
|  | flags:            []string{"-peek-then-read"}, | 
|  | }) | 
|  | } |