use the fuzzing helper functions to generate the frames seed corpus

This commit is contained in:
Marten Seemann 2020-08-25 12:59:14 +07:00
parent 745e51ac4f
commit 5090dd6199
65 changed files with 31 additions and 71 deletions

2
.gitignore vendored
View file

@ -11,5 +11,3 @@ fuzzing/*/crashers
fuzzing/*/sonarprofile
fuzzing/*/suppressions
fuzzing/*/corpus/
!fuzzing/frames/single-frame*
!fuzzing/frames/multiple-frame*

View file

@ -2,12 +2,12 @@ package main
import (
"bytes"
"fmt"
"log"
"math/rand"
"os"
"time"
"github.com/lucas-clemente/quic-go"
"github.com/lucas-clemente/quic-go/fuzzing/internal/helper"
"github.com/lucas-clemente/quic-go/internal/protocol"
"github.com/lucas-clemente/quic-go/internal/qerr"
"github.com/lucas-clemente/quic-go/internal/wire"
@ -246,19 +246,17 @@ func getFrames() []wire.Frame {
}
func main() {
rand.Seed(42)
for i, f := range getFrames() {
for _, f := range getFrames() {
b := &bytes.Buffer{}
if err := f.Write(b, version); err != nil {
panic(err)
log.Fatal(err)
}
if err := writeCorpusFile(fmt.Sprintf("single-frame-%d", i), b.Bytes()); err != nil {
panic(err)
if err := helper.WriteCorpusFileWithPrefix("corpus", b.Bytes(), 1); err != nil {
log.Fatal(err)
}
}
for i := 0; i < 25; i++ {
for i := 0; i < 30; i++ {
frames := getFrames()
b := &bytes.Buffer{}
@ -268,26 +266,14 @@ func main() {
}
f := frames[rand.Intn(len(frames))]
if err := f.Write(b, version); err != nil {
panic(err)
log.Fatal(err)
}
if rand.Intn(10) == 0 { // write a PADDING frame
b.WriteByte(0x0)
}
}
if err := writeCorpusFile(fmt.Sprintf("multiple-frames-%d", i), b.Bytes()); err != nil {
panic(err)
if err := helper.WriteCorpusFileWithPrefix("corpus", b.Bytes(), 1); err != nil {
log.Fatal(err)
}
}
}
func writeCorpusFile(name string, data []byte) error {
file, err := os.Create("corpus/" + name)
if err != nil {
return err
}
data = append(getRandomData(1), data...)
if _, err := file.Write(data); err != nil {
return err
}
return file.Close()
}

View file

@ -1 +0,0 @@
���

View file

@ -1 +0,0 @@
d ´ŮÉ ÝťRß×›MvB›az źź ;Ą[ ŔÖL�…5„Ëŕp›X?aÓuĽ´ôů)áŹÚžo‚ĺNtŽ�çžK˝oăLÜş„>čÖ>ŚOţëęTmŹ¬Ý¬Î.˘‡|UyϢǎ

View file

@ -1 +0,0 @@
W

View file

@ -1 +0,0 @@
�fL�l�Q5

View file

@ -1 +0,0 @@
���Mp��������

View file

@ -1,2 +0,0 @@
6
u*.租マ�メ

View file

@ -1 +0,0 @@
wK

View file

@ -1 +0,0 @@
���������

View file

@ -1 +0,0 @@
�H�

Binary file not shown.

View file

@ -1 +0,0 @@
���u���������

View file

@ -1 +0,0 @@
Z•ňG&

View file

@ -1 +0,0 @@
•`Ο

View file

@ -1 +0,0 @@
�

View file

@ -1 +0,0 @@
���������

View file

@ -1 +0,0 @@
�5z�

View file

@ -1 +0,0 @@
k€��������

View file

@ -1 +0,0 @@
В•Ј.

View file

@ -1 +0,0 @@
���M

View file

@ -1 +0,0 @@
��H�f

View file

@ -1 +0,0 @@
w .T^'?ăWkoí'˙‰tşŔĘýšĐV’±6ç8–MýÇžŤSCsfýf×Oě‰I·#n

View file

@ -1 +0,0 @@
 @d=€çËż‡ŇŮ) ¤yĄ[{säď˛ACN6ÔO}y8Ťˇž\ţ�!cu�&ß9ř3i\˘*¦Q•H�ĽÜĎf­=s¨á«ź�‡}&;»'őĽI{ÖTGMˆ*´Ýh› M ®h �ÖĄčtÄä®

View file

@ -1 +0,0 @@
w˝[ŢmĽ!źvť)n§vDݸ#¨/ş

View file

@ -1,3 +0,0 @@
|¬ז�ֹ¬ז�ֹ¿0לע_¦fֹ$k],W�ן}
RKT’»ק*ֳN�¹
^�

View file

@ -1,2 +0,0 @@
} gʆ+«ÔKu!_²‚ˆ]2`ñÞ—‚ƒÔ š6ùl ”FãíM¦F©®‹O§´ü: ºúuí2z†¸°ÃšñÏÒ³µêyS:¿D�,G�2`u3�YÈÌð�£ž’�J¼¼±i9{·4çï
nñ…Më_ä$þ÷¬!‘õ—^)*¢¸ª|aͳ3sëç,' ˜À!—Úæ·2ÃQßf�‡N,Ÿàœ¨`çâH0?ô#áHíS�h_vò§˜¼dÞ]²†K*ÓÂlæ8#BvZÖ–å-÷`öÃF^) Ü¤jàÕp;ÂqõõJd1Q?ØB›Jẟ*ƒ†®r³fè,*ÆM¿F

View file

@ -1 +0,0 @@
¦ ^Эяяяяяяяъ$в0S

View file

@ -1 +0,0 @@
G ’Wô†ÿÿÿÿÿÿÿÿcF ð×Ð}Å

Binary file not shown.

View file

@ -1 +0,0 @@
·ÊÕïdŠ€½³ÈXùÂÕß™Áaé/¨À³ªÙ5°yÀšò</RSÀôcÜ�ÀæÿŒŠ³‡ÀK4¾×ÀL:š†Û£À´/•²Ì2

Binary file not shown.

View file

@ -8,27 +8,34 @@ import (
"github.com/lucas-clemente/quic-go/internal/wire"
)
const version = protocol.VersionTLS
// PrefixLen is the number of bytes used for configuration
const PrefixLen = 1
func toEncLevel(v uint8) protocol.EncryptionLevel {
switch v % 3 {
default:
return protocol.EncryptionInitial
case 1:
return protocol.EncryptionHandshake
case 2:
return protocol.Encryption1RTT
}
}
// Fuzz fuzzes the QUIC frames.
//go:generate go run ./cmd/corpus.go
func Fuzz(data []byte) int {
const version = protocol.VersionTLS
if len(data) < 1 {
if len(data) < PrefixLen {
return 0
}
encLevel := toEncLevel(data[0])
data = data[PrefixLen:]
parser := wire.NewFrameParser(version)
parser.SetAckDelayExponent(protocol.DefaultAckDelayExponent)
var encLevel protocol.EncryptionLevel
switch data[0] % 3 {
case 0:
encLevel = protocol.EncryptionInitial
case 1:
encLevel = protocol.EncryptionHandshake
case 2:
encLevel = protocol.Encryption1RTT
}
data = data[1:]
r := bytes.NewReader(data)
initialLen := r.Len()