From e808bdaa15b4df61d9575192fc34cde77890da1c Mon Sep 17 00:00:00 2001 From: Runxi Yu Date: Fri, 6 Mar 2026 16:23:26 +0800 Subject: format/sideband64k: Add side-band-64k --- .../encoder_buffered_flush_behavior_test.go | 48 ++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 format/sideband64k/encoder_buffered_flush_behavior_test.go (limited to 'format/sideband64k/encoder_buffered_flush_behavior_test.go') diff --git a/format/sideband64k/encoder_buffered_flush_behavior_test.go b/format/sideband64k/encoder_buffered_flush_behavior_test.go new file mode 100644 index 00000000..f804f231 --- /dev/null +++ b/format/sideband64k/encoder_buffered_flush_behavior_test.go @@ -0,0 +1,48 @@ +package sideband64k_test + +import ( + "bufio" + "bytes" + "testing" + + "codeberg.org/lindenii/furgit/format/sideband64k" +) + +func TestEncoderBufferedFlushBehavior(t *testing.T) { + t.Parallel() + + var out bytes.Buffer + + bw := bufio.NewWriter(&out) + enc := sideband64k.NewEncoder(bw) + + if err := enc.WriteData([]byte("hello")); err != nil { + t.Fatalf("WriteData: %v", err) + } + if err := enc.WriteFlush(); err != nil { + t.Fatalf("WriteFlush: %v", err) + } + if out.Len() != 0 { + t.Fatalf("WriteFlush should not flush I/O, got %q", out.String()) + } + if err := enc.FlushIO(); err != nil { + t.Fatalf("FlushIO: %v", err) + } + if got, want := out.String(), "000a\x01hello0000"; got != want { + t.Fatalf("got %q, want %q", got, want) + } + + out.Reset() + bw = bufio.NewWriter(&out) + enc = sideband64k.NewEncoder(bw) + + if err := enc.WriteData([]byte("yo")); err != nil { + t.Fatalf("WriteData: %v", err) + } + if err := enc.WriteFlushAndFlushIO(); err != nil { + t.Fatalf("WriteFlushAndFlushIO: %v", err) + } + if got, want := out.String(), "0007\x01yo0000"; got != want { + t.Fatalf("got %q, want %q", got, want) + } +} -- cgit v1.3.1-10-gc9f91