在内存中“列表附加器”; 对于 log4j

发布于 2024-07-27 20:07:17 字数 55 浏览 7 评论 0原文

log4j 是否有一个仅存储日志记录事件列表的附加程序(用于单元测试,以验证没有写入错误日志)?

Is there an appender for log4j that only stores a list of the logging events (to be used in unit tests, to verify no error logs were written) ?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

落花浅忆 2024-08-03 20:07:17

有一个 MemoryAppender,但它不是标准的一部分log4j 库。

您可以轻松编写自己的代码,但如果您仅将它们用于单元测试,我可能会模拟记录器并断言不会对其进行任何调用。 重写目标类中的 getLogger() 方法或直接在类型上设置模拟 Logger。

使用 Jmock(记忆中的示例,如有错误,敬请谅解):

public void testDoFoo() {
    Mockery mockery = new Mockery();
    Logger mockLogger = mockery.mock(Logger.class);

    Foo foo = new Foo();

    foo.setLogger(mockLogger);

    mockery.checking(new Expectations() {
        {
            never(mockLogger).debug(with(any(String.class));
        }
    };

    ...
    //do the actual test.

    //assert the mock type has never been called.
    mockery.assertIsSatisfied();
}

There is a MemoryAppender, but it's not part of the standard log4j library.

You could easily write your own, But if you are only using them for unit tests I would probably mock the Logger and assert no calls are made to it. Override the getLogger() method in the target class or set the mock Logger directly on the type.

Using Jmock (example from memory, sorry for any errors):

public void testDoFoo() {
    Mockery mockery = new Mockery();
    Logger mockLogger = mockery.mock(Logger.class);

    Foo foo = new Foo();

    foo.setLogger(mockLogger);

    mockery.checking(new Expectations() {
        {
            never(mockLogger).debug(with(any(String.class));
        }
    };

    ...
    //do the actual test.

    //assert the mock type has never been called.
    mockery.assertIsSatisfied();
}
酒绊 2024-08-03 20:07:17

我不相信有。 不过,您可以轻松地自己编写。 这是一个合适的教程

I don't believe there is. You can write your own easily, though. Here's a suitable tutorial.

滿滿的愛 2024-08-03 20:07:17

这是记录器附加程序的示例实现,它将所有事件存储在内存中(在 StringBuilder 中); 然后可以使用 getResult 检索内容:

package apackage;

import org.apache.log4j.AppenderSkeleton;
import org.apache.log4j.spi.LoggingEvent;

/**
 * Records logging events in a String.
 * 
 * @author Lorenzo Bettini
 *
 */
public class InMemoryLoggerAppender extends AppenderSkeleton {

    private StringBuilder builder = new StringBuilder();

    @Override
    public void close() {
        // nothing to close
    }

    @Override
    public boolean requiresLayout() {
        return false;
    }

    @Override
    protected void append(LoggingEvent event) {
        builder.append(
            event.getLevel() + ": " + event.getMessage().toString()
            + System.lineSeparator());
    }

    public String getResult() {
        return builder.toString();
    }
}

例如,您必须将此附加器添加到现有的 Logger(MyClass 是使用 Logger 来记录您想要捕获的事件):

InMemoryLoggerAppender appender = new InMemoryLoggerAppender();
Logger log = Logger.getLogger(MyClass.class);
log.addAppender(appender);

This is an example implementation of a logger appender, that stores all the events in memory (in a StringBuilder); the contents can then be retrieved with getResult:

package apackage;

import org.apache.log4j.AppenderSkeleton;
import org.apache.log4j.spi.LoggingEvent;

/**
 * Records logging events in a String.
 * 
 * @author Lorenzo Bettini
 *
 */
public class InMemoryLoggerAppender extends AppenderSkeleton {

    private StringBuilder builder = new StringBuilder();

    @Override
    public void close() {
        // nothing to close
    }

    @Override
    public boolean requiresLayout() {
        return false;
    }

    @Override
    protected void append(LoggingEvent event) {
        builder.append(
            event.getLevel() + ": " + event.getMessage().toString()
            + System.lineSeparator());
    }

    public String getResult() {
        return builder.toString();
    }
}

You then have to add this appender to an existing Logger, for example (MyClass is the class that uses a Logger to log events you want to capture):

InMemoryLoggerAppender appender = new InMemoryLoggerAppender();
Logger log = Logger.getLogger(MyClass.class);
log.addAppender(appender);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文