go-rfc2616/eol/bytes_tolerant_test.go

131 lines
2.5 KiB
Go

package eol_test
import (
"testing"
"bytes"
"sourcecode.social/reiver/go-rfc2616/eol"
)
func TestBytesTolerant(t *testing.T) {
tests := []struct{
Value []byte
ExpectedResult []byte
ExpectedRest []byte
ExpectedOK bool
}{
{
Value: nil,
ExpectedResult: nil,
ExpectedRest: nil,
ExpectedOK: false,
},
{
Value: []byte(nil),
ExpectedResult: nil,
ExpectedRest: nil,
ExpectedOK: false,
},
{
Value: []byte{},
ExpectedResult: nil,
ExpectedRest: nil,
ExpectedOK: false,
},
{
Value: []byte(""),
ExpectedResult: nil,
ExpectedRest: nil,
ExpectedOK: false,
},
{
Value : []byte("\n"),
ExpectedResult: []byte("\n"),
ExpectedRest: nil,
ExpectedOK: true,
},
{
Value : []byte("\r\n"),
ExpectedResult: []byte("\r\n"),
ExpectedRest: nil,
ExpectedOK: true,
},
{
Value : []byte("\nHost: example.com\n"),
ExpectedResult: []byte("\n"),
ExpectedRest: []byte("Host: example.com\n"),
ExpectedOK: true,
},
{
Value : []byte("\r\nHost: example.com\r\n"),
ExpectedResult: []byte("\r\n"),
ExpectedRest: []byte("Host: example.com\r\n"),
ExpectedOK: true,
},
{
Value: []byte("\r"),
ExpectedResult: nil,
ExpectedRest: []byte("\r"),
ExpectedOK: false,
},
}
for testNumber, test := range tests {
actualResult, actualRest, actualOK := eol.BytesTolerant(test.Value)
{
expected := test.ExpectedOK
actual := actualOK
if expected != actual {
t.Errorf("For test #%d, the actual ok-result is not what wad expected.", testNumber)
t.Logf("EXPECTED: %t", expected)
t.Logf("ACTUAL: %t", actual)
t.Logf("VALUE: %q (%#v)", test.Value, test.Value)
continue
}
}
{
expected := test.ExpectedResult
actual := actualResult
if !bytes.Equal(expected, actual) {
t.Errorf("For test #%d, the actual result is not what wad expected.", testNumber)
t.Logf("EXPECTED: %q (%#v)", expected, expected)
t.Logf("ACTUAL: %q (%#v)", actual, actual)
t.Logf("VALUE: %q (%#v)", test.Value, test.Value)
continue
}
}
{
expected := test.ExpectedRest
actual := actualRest
if !bytes.Equal(expected, actual) {
t.Errorf("For test #%d, the actual rest is not what wad expected.", testNumber)
t.Logf("EXPECTED: %q (%#v)", expected, expected)
t.Logf("ACTUAL: %q (%#v)", actual, actual)
t.Logf("VALUE: %q (%#v)", test.Value, test.Value)
continue
}
}
}
}