Commit a56f5a03 authored by Klaus Post's avatar Klaus Post Committed by Brad Fitzpatrick

compress/flate: improve short writer error test

This improves the short version of the writer test.

First of all, it has a much quicker setup. Previously that
could take up towards 0.5 second.

Secondly, it will test all compression levels in short mode as well.

Execution time is 1.7s/0.03s for normal/short mode.

Change-Id: I275a21f712daff6f7125cc6a493415e86439cb19
Reviewed-on: https://go-review.googlesource.com/21800Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent f20b1809
...@@ -86,14 +86,18 @@ func (e *errorWriter) Write(b []byte) (int, error) { ...@@ -86,14 +86,18 @@ func (e *errorWriter) Write(b []byte) (int, error) {
// Test if errors from the underlying writer is passed upwards. // Test if errors from the underlying writer is passed upwards.
func TestWriteError(t *testing.T) { func TestWriteError(t *testing.T) {
buf := new(bytes.Buffer) buf := new(bytes.Buffer)
for i := 0; i < 1024*1024; i++ { n := 65536
if !testing.Short() {
n *= 4
}
for i := 0; i < n; i++ {
buf.WriteString(fmt.Sprintf("asdasfasf%d%dfghfgujyut%dyutyu\n", i, i, i)) buf.WriteString(fmt.Sprintf("asdasfasf%d%dfghfgujyut%dyutyu\n", i, i, i))
} }
in := buf.Bytes() in := buf.Bytes()
// We create our own buffer to control number of writes. // We create our own buffer to control number of writes.
copyBuffer := make([]byte, 1024) copyBuffer := make([]byte, 128)
for l := 0; l < 10; l++ { for l := 0; l < 10; l++ {
for fail := 1; fail <= 512; fail *= 2 { for fail := 1; fail <= 256; fail *= 2 {
// Fail after 'fail' writes // Fail after 'fail' writes
ew := &errorWriter{N: fail} ew := &errorWriter{N: fail}
w, err := NewWriter(ew, l) w, err := NewWriter(ew, l)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment