github.com/decred/dcrlnd@v0.7.6/fuzz/brontide/random_init_decrypt.go (about)

     1  //go:build gofuzz
     2  // +build gofuzz
     3  
     4  package brontidefuzz
     5  
     6  import (
     7  	"bytes"
     8  )
     9  
    10  // Fuzz_random_init_decrypt is a go-fuzz harness that decrypts arbitrary data
    11  // with the initiator.
    12  func Fuzz_random_init_decrypt(data []byte) int {
    13  	// This will return brontide machines with random keys.
    14  	initiator, responder := getBrontideMachines()
    15  
    16  	// Complete the brontide handshake.
    17  	completeHandshake(initiator, responder)
    18  
    19  	// Create a reader with the byte array.
    20  	r := bytes.NewReader(data)
    21  
    22  	// Decrypt the encrypted message using ReadMessage w/ initiator machine.
    23  	if _, err := initiator.ReadMessage(r); err == nil {
    24  		nilAndPanic(initiator, responder, nil)
    25  	}
    26  
    27  	return 1
    28  }