autogits/bots-common/log_test.go

61 lines
1.6 KiB
Go
Raw Normal View History

2024-07-07 21:08:41 +02:00
package common
2024-09-10 18:24:41 +02:00
/*
* This file is part of Autogits.
*
* Copyright © 2024 SUSE LLC
*
* Autogits is free software: you can redistribute it and/or modify it under
* the terms of the GNU General Public License as published by the Free Software
* Foundation, either version 2 of the License, or (at your option) any later
* version.
*
* Autogits is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with
* Foobar. If not, see <https://www.gnu.org/licenses/>.
*/
2024-07-07 21:08:41 +02:00
import (
2024-08-24 13:32:39 +02:00
"bytes"
2024-07-07 21:08:41 +02:00
"regexp"
"testing"
)
type TestWriter struct {
str string
}
func TestLogging(t *testing.T) {
t.Run("basic logging", func(t *testing.T) {
2024-08-24 13:32:39 +02:00
var strWriter, errWriter *bytes.Buffer
2024-07-07 21:08:41 +02:00
2024-08-24 13:32:39 +02:00
strWriter = bytes.NewBuffer(make([]byte, 0, 10000))
errWriter = bytes.NewBuffer(make([]byte, 0, 10000))
2024-07-07 21:08:41 +02:00
2024-08-24 13:32:39 +02:00
stdLogger, errLogger := CreateStdoutLogger(strWriter, errWriter)
errLogger.Printf("%d\n", 100)
stdLogger.Printf("OKA %d Done\n", 77)
stdLogger.Println("Another line")
2024-07-07 21:08:41 +02:00
2024-08-28 17:53:15 +02:00
const prefixMatch = `\[\d+\] `
2024-07-07 21:08:41 +02:00
2024-08-28 17:53:15 +02:00
errStr := errWriter.String()
if ok, err := regexp.MatchString("^"+prefixMatch+"100\n$", errStr); !ok {
2024-07-07 21:08:41 +02:00
if err != nil {
t.Logf("err: %v", err)
}
2024-08-28 17:53:15 +02:00
t.Fatal(errStr)
2024-07-07 21:08:41 +02:00
}
2024-08-24 13:32:39 +02:00
str := strWriter.String()
if ok, err := regexp.MatchString("^"+prefixMatch+"OKA 77 Done\n"+prefixMatch+"Another line\n$", str); !ok {
2024-07-07 21:08:41 +02:00
if err != nil {
t.Logf("err: %v", err)
}
2024-08-24 13:32:39 +02:00
t.Fatal(str)
2024-07-07 21:08:41 +02:00
}
})
}