go-eol/readlf_test.go

210 lines
5.5 KiB
Go
Raw Normal View History

2023-11-27 19:32:08 +00:00
package eol_test
import (
"testing"
"io"
"strings"
"sourcecode.social/reiver/go-utf8"
"sourcecode.social/reiver/go-eol"
)
func TestReadLF(t *testing.T) {
tests := []struct{
Value string
ExpectedSize int
}{
{
Value: "\n",
ExpectedSize: 1,
},
{
Value: "\napple banana cherry",
ExpectedSize: 1,
},
}
for testNumber, test := range tests {
var reader io.Reader = strings.NewReader(test.Value)
var runescanner io.RuneScanner = utf8.NewRuneScanner(reader)
actualSize, err := eol.ReadLF(runescanner)
if nil != err {
t.Errorf("For test #%d, did not expect an error but actually got one.", testNumber)
t.Logf("ERROR: (%T) %s", err, err)
t.Logf("VALUE: %q", test.Value)
continue
}
{
expected := test.ExpectedSize
actual := actualSize
if expected != actual {
t.Errorf("For test #%d, the actual size is not what was expected.", testNumber)
t.Logf("EXPECTED: %d", expected)
t.Logf("ACTUAL: %d", actual)
t.Logf("VALUE: %q", test.Value)
continue
}
}
}
}
func TestReadLF_fail(t *testing.T) {
tests := []struct{
Value string
ExpectedError string
}{
{
Value: "",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: problem reading character №1 of end-of-line sequence "\n": EOF`,
2023-11-27 19:32:08 +00:00
},
{
Value: "\r",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '\r' (U+000D)`,
2023-11-27 19:32:08 +00:00
},
{
Value: "\u0085",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '\u0085' (U+0085)`,
2023-11-27 19:32:08 +00:00
},
{
Value: "\u2028",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '\u2028' (U+2028)`,
2023-11-27 19:32:08 +00:00
},
{
Value: "😈",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '😈' (U+1F608)`,
2023-11-27 19:32:08 +00:00
},
{
Value: "\rapple banana cherry",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '\r' (U+000D)`,
2023-11-27 19:32:08 +00:00
},
{
Value: "\u0085apple banana cherry",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '\u0085' (U+0085)`,
2023-11-27 19:32:08 +00:00
},
{
Value: "\u2028apple banana cherry",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '\u2028' (U+2028)`,
2023-11-27 19:32:08 +00:00
},
{
Value: "😈apple banana cherry",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '😈' (U+1F608)`,
2023-11-27 19:32:08 +00:00
},
{
Value: " \n",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found ' ' (U+0020)`,
2023-11-27 19:32:08 +00:00
},
{
Value: " \r",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found ' ' (U+0020)`,
2023-11-27 19:32:08 +00:00
},
{
Value: " \u0085",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found ' ' (U+0020)`,
2023-11-27 19:32:08 +00:00
},
{
Value: " \u2028",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found ' ' (U+0020)`,
2023-11-27 19:32:08 +00:00
},
{
Value: " 😈",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found ' ' (U+0020)`,
2023-11-27 19:32:08 +00:00
},
{
Value: ".\n",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '.' (U+002E)`,
2023-11-27 19:32:08 +00:00
},
{
Value: ".\r",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '.' (U+002E)`,
2023-11-27 19:32:08 +00:00
},
{
Value: ".\u0085",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '.' (U+002E)`,
2023-11-27 19:32:08 +00:00
},
{
Value: ".\u2028",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '.' (U+002E)`,
2023-11-27 19:32:08 +00:00
},
{
Value: ".😈",
2023-11-28 16:08:06 +00:00
ExpectedError: `eol: line-feed (LF) character ('\n') (U+000A) not found for end-of-line sequence "\n" character №1 — instead found '.' (U+002E)`,
2023-11-27 19:32:08 +00:00
},
}
for testNumber, test := range tests {
var reader io.Reader = strings.NewReader(test.Value)
var runescanner io.RuneScanner = utf8.NewRuneScanner(reader)
actualSize, err := eol.ReadLF(runescanner)
if nil == err {
t.Errorf("For test #%d, expected an error but did not actually get one.", testNumber)
t.Logf("EXPECTED-ERROR: %q", test.ExpectedError)
t.Logf("VALUE: %q", test.Value)
continue
}
{
expected := test.ExpectedError
actual := err.Error()
if expected != actual {
t.Errorf("For test #%d, the actual error is not what was expected.", testNumber)
t.Logf("EXPECTED: %q", expected)
t.Logf("ACTUAL: %q", actual)
t.Logf("VALUE: %q", test.Value)
continue
}
}
{
expected := 0
actual := actualSize
if expected != actual {
t.Errorf("For test #%d, the actual size is not what was expected.", testNumber)
t.Logf("EXPECTED: %d", expected)
t.Logf("ACTUAL: %d", actual)
t.Logf("VALUE: %q", test.Value)
continue
}
}
}
}