|  | // Copyright 2020 The Monogon Project Authors. | 
|  | // | 
|  | // SPDX-License-Identifier: Apache-2.0 | 
|  | // | 
|  | // Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | // you may not use this file except in compliance with the License. | 
|  | // You may obtain a copy of the License at | 
|  | // | 
|  | //     http://www.apache.org/licenses/LICENSE-2.0 | 
|  | // | 
|  | // Unless required by applicable law or agreed to in writing, software | 
|  | // distributed under the License is distributed on an "AS IS" BASIS, | 
|  | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | // See the License for the specific language governing permissions and | 
|  | // limitations under the License. | 
|  |  | 
|  | package logbuffer | 
|  |  | 
|  | import ( | 
|  | "fmt" | 
|  | "testing" | 
|  | ) | 
|  |  | 
|  | func TestLineBuffer(t *testing.T) { | 
|  | var lines []*Line | 
|  | lb := NewLineBuffer(1024, func(l *Line) { | 
|  | lines = append(lines, l) | 
|  | }) | 
|  |  | 
|  | compare := func(a []*Line, b ...string) string { | 
|  | msg := fmt.Sprintf("want %v, got %v", a, b) | 
|  | if len(a) != len(b) { | 
|  | return msg | 
|  | } | 
|  | for i, _ := range a { | 
|  | if a[i].String() != b[i] { | 
|  | return msg | 
|  | } | 
|  | } | 
|  | return "" | 
|  | } | 
|  |  | 
|  | // Write some data. | 
|  | fmt.Fprintf(lb, "foo ") | 
|  | if diff := compare(lines); diff != "" { | 
|  | t.Fatal(diff) | 
|  | } | 
|  | fmt.Fprintf(lb, "bar\n") | 
|  | if diff := compare(lines, "foo bar"); diff != "" { | 
|  | t.Fatal(diff) | 
|  | } | 
|  | fmt.Fprintf(lb, "baz") | 
|  | if diff := compare(lines, "foo bar"); diff != "" { | 
|  | t.Fatal(diff) | 
|  | } | 
|  | fmt.Fprintf(lb, " baz") | 
|  | if diff := compare(lines, "foo bar"); diff != "" { | 
|  | t.Fatal(diff) | 
|  | } | 
|  | // Close and expect flush. | 
|  | if err := lb.Close(); err != nil { | 
|  | t.Fatalf("Close: %v", err) | 
|  | } | 
|  | if diff := compare(lines, "foo bar", "baz baz"); diff != "" { | 
|  | t.Fatal(diff) | 
|  | } | 
|  |  | 
|  | // Check behaviour after close | 
|  | if _, err := fmt.Fprintf(lb, "nope"); err == nil { | 
|  | t.Fatalf("Write after Close: wanted  error, got nil") | 
|  | } | 
|  | if err := lb.Close(); err == nil { | 
|  | t.Fatalf("second Close: wanted error, got nil") | 
|  | } | 
|  | } |