mirror of
https://gitee.com/gitea/gitea.git
synced 2024-12-15 10:00:49 +08:00
911975059a
Before, there was a `log/buffer.go`, but that design is not general, and it introduces a lot of irrelevant `Content() (string, error) ` and `return "", fmt.Errorf("not supported")` . And the old `log/buffer.go` is difficult to use, developers have to write a lot of `Contains` and `Sleep` code. The new `LogChecker` is designed to be a general approach to help to assert some messages appearing or not appearing in logs.
26 lines
633 B
Go
26 lines
633 B
Go
// Copyright 2019 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package log
|
|
|
|
// LoggerProvider represents behaviors of a logger provider.
|
|
type LoggerProvider interface {
|
|
Init(config string) error
|
|
EventLogger
|
|
}
|
|
|
|
type loggerProvider func() LoggerProvider
|
|
|
|
var providers = make(map[string]loggerProvider)
|
|
|
|
// Register registers given logger provider to providers.
|
|
func Register(name string, log loggerProvider) {
|
|
if log == nil {
|
|
panic("log: register provider is nil")
|
|
}
|
|
if _, dup := providers[name]; dup {
|
|
panic("log: register called twice for provider \"" + name + "\"")
|
|
}
|
|
providers[name] = log
|
|
}
|