mirror of
https://github.com/dutchcoders/transfer.sh.git
synced 2025-01-12 11:50:18 +01:00
Fuzz local storage test
This commit is contained in:
parent
b40e9d1fb8
commit
8c5ef8f2e1
3 changed files with 69 additions and 109 deletions
|
@ -29,7 +29,7 @@ jobs:
|
||||||
dist: bionic
|
dist: bionic
|
||||||
script: ./fuzzit.sh local-regression
|
script: ./fuzzit.sh local-regression
|
||||||
- stage: Fuzz
|
- stage: Fuzz
|
||||||
if: branch = master AND type IN (push)
|
if: branch = fuzz AND type IN (push)
|
||||||
go: 1.12.x
|
go: 1.12.x
|
||||||
dist: bionic
|
dist: bionic
|
||||||
script: ./fuzzit.sh fuzzing
|
script: ./fuzzit.sh fuzzing
|
||||||
|
@ -53,5 +53,5 @@ deploy:
|
||||||
skip_cleanup: true
|
skip_cleanup: true
|
||||||
on:
|
on:
|
||||||
tags: true
|
tags: true
|
||||||
go: tip
|
go: 1.12.x
|
||||||
overwrite: true
|
overwrite: true
|
||||||
|
|
|
@ -30,6 +30,4 @@ function fuzz {
|
||||||
clang -fsanitize=fuzzer fuzzer.a -o fuzzer
|
clang -fsanitize=fuzzer fuzzer.a -o fuzzer
|
||||||
./fuzzit create job --type $TYPE $NAME/$TARGET fuzzer
|
./fuzzit create job --type $TYPE $NAME/$TARGET fuzzer
|
||||||
}
|
}
|
||||||
fuzz Profile profile
|
fuzz LocalStorage local-storage
|
||||||
fuzz HTTP http
|
|
||||||
fuzz HTTPS https
|
|
||||||
|
|
|
@ -3,126 +3,88 @@
|
||||||
package server
|
package server
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"crypto/tls"
|
"bytes"
|
||||||
"io/ioutil"
|
"io"
|
||||||
"net"
|
"math/rand"
|
||||||
"strings"
|
"reflect"
|
||||||
)
|
)
|
||||||
|
|
||||||
// FuzzProfile tests the profile server.
|
const applicationOctetStream = "application/octet-stream"
|
||||||
func FuzzProfile(fuzz []byte) int {
|
|
||||||
if len(fuzz) == 0 {
|
// FuzzLocalStorage tests the Local Storage.
|
||||||
|
func FuzzLocalStorage(fuzz []byte) int {
|
||||||
|
var fuzzLength = uint64(len(fuzz))
|
||||||
|
if fuzzLength == 0 {
|
||||||
return -1
|
return -1
|
||||||
}
|
}
|
||||||
server, err := New(EnableProfiler())
|
|
||||||
if err != nil {
|
|
||||||
panic(err.Error())
|
|
||||||
}
|
|
||||||
server.Run()
|
|
||||||
defer server.profileListener.Close()
|
|
||||||
defer server.httpListener.Close()
|
|
||||||
address := server.profileListener.Addr
|
|
||||||
connection, err := net.Dial("tcp", address)
|
|
||||||
if err != nil {
|
|
||||||
panic(err.Error())
|
|
||||||
}
|
|
||||||
_, err = connection.Write(fuzz)
|
|
||||||
if err != nil {
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
response, err := ioutil.ReadAll(connection)
|
|
||||||
if err != nil {
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
err = connection.Close()
|
|
||||||
if err != nil {
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
fields := strings.Fields(string(response))
|
|
||||||
if len(fields) < 2 {
|
|
||||||
panic("invalid HTTP response")
|
|
||||||
}
|
|
||||||
code := fields[1]
|
|
||||||
if code == "500" {
|
|
||||||
panic("server panicked")
|
|
||||||
}
|
|
||||||
return 1
|
|
||||||
}
|
|
||||||
|
|
||||||
// FuzzHTTP tests the HTTP server.
|
storage, err := NewLocalStorage("/tmp", nil)
|
||||||
func FuzzHTTP(fuzz []byte) int {
|
|
||||||
if len(fuzz) == 0 {
|
|
||||||
return -1
|
|
||||||
}
|
|
||||||
server, err := New(Listener("localhost"))
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err.Error())
|
panic("unable to create local storage")
|
||||||
}
|
|
||||||
server.Run()
|
|
||||||
defer server.httpListener.Close()
|
|
||||||
address := server.httpListener.Addr
|
|
||||||
connection, err := net.Dial("tcp", address)
|
|
||||||
if err != nil {
|
|
||||||
panic(err.Error())
|
|
||||||
}
|
|
||||||
_, err = connection.Write(fuzz)
|
|
||||||
if err != nil {
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
response, err := ioutil.ReadAll(connection)
|
|
||||||
if err != nil {
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
err = connection.Close()
|
|
||||||
if err != nil {
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
fields := strings.Fields(string(response))
|
|
||||||
if len(fields) < 2 {
|
|
||||||
panic("invalid HTTP response")
|
|
||||||
}
|
|
||||||
code := fields[1]
|
|
||||||
if code == "500" {
|
|
||||||
panic("server panicked")
|
|
||||||
}
|
|
||||||
return 1
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// FuzzHTTPS tests the HTTPS server.
|
token := Encode(10000000 + int64(rand.Intn(1000000000)))
|
||||||
func FuzzHTTPS(fuzz []byte) int {
|
filename := Encode(10000000 + int64(rand.Intn(1000000000))) + ".bin"
|
||||||
if len(fuzz) == 0 {
|
|
||||||
return -1
|
input := bytes.NewReader(fuzz)
|
||||||
}
|
err = storage.Put(token, filename, input, applicationOctetStream, fuzzLength)
|
||||||
server, err := New(TLSListener("localhost", true))
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err.Error())
|
panic("unable to save file")
|
||||||
}
|
}
|
||||||
server.Run()
|
|
||||||
defer server.httpsListener.Close()
|
contentType, contentLength, err := storage.Head(token, filename)
|
||||||
address := server.httpsListener.Addr
|
|
||||||
connection, err := tls.Dial("tcp", address, nil)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err.Error())
|
panic("not visible through head")
|
||||||
}
|
}
|
||||||
_, err = connection.Write(fuzz)
|
|
||||||
|
if contentType != applicationOctetStream {
|
||||||
|
panic("incorrect content type")
|
||||||
|
}
|
||||||
|
|
||||||
|
if contentLength != fuzzLength {
|
||||||
|
panic("incorrect content length")
|
||||||
|
}
|
||||||
|
|
||||||
|
output, contentType, contentLength, err := storage.Get(token, filename)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0
|
panic("not visible through get")
|
||||||
}
|
}
|
||||||
response, err := ioutil.ReadAll(connection)
|
|
||||||
|
if contentType != applicationOctetStream {
|
||||||
|
panic("incorrect content type")
|
||||||
|
}
|
||||||
|
|
||||||
|
if contentLength != fuzzLength {
|
||||||
|
panic("incorrect content length")
|
||||||
|
}
|
||||||
|
|
||||||
|
var length uint64
|
||||||
|
b := make([]byte, len(fuzz))
|
||||||
|
for {
|
||||||
|
n, err := output.Read(b)
|
||||||
|
length += uint64(n)
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if !reflect.DeepEqual(b, fuzz) {
|
||||||
|
panic("incorrect content body")
|
||||||
|
}
|
||||||
|
|
||||||
|
if length != fuzzLength {
|
||||||
|
panic("incorrect content length")
|
||||||
|
}
|
||||||
|
|
||||||
|
err = storage.Delete(token, filename)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0
|
panic("unable to delete file")
|
||||||
}
|
}
|
||||||
err = connection.Close()
|
|
||||||
if err != nil {
|
_, _, err = storage.Head(token, filename)
|
||||||
return 0
|
if !storage.IsNotExist(err) {
|
||||||
}
|
panic("file not deleted")
|
||||||
fields := strings.Fields(string(response))
|
|
||||||
if len(fields) < 2 {
|
|
||||||
panic("invalid HTTP response")
|
|
||||||
}
|
|
||||||
code := fields[1]
|
|
||||||
if code == "500" {
|
|
||||||
panic("server panicked")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue