aboutsummaryrefslogtreecommitdiffstats
path: root/node-repository/src/main/java/com/yahoo/vespa/hosted/provision/testutils/InMemoryProvisionLogger.java
blob: 4b07d61b411a6bc50340278bdce951e58ac2cf62 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.vespa.hosted.provision.testutils;

import com.yahoo.config.provision.ProvisionLogger;

import java.util.ArrayList;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;

/**
 * A logger which remembers all messages logged in addition to writing them to standard out.
 *
 * @author bratseth
 */
public class InMemoryProvisionLogger implements ProvisionLogger {

    private static final Logger LOG = Logger.getLogger(InMemoryProvisionLogger.class.getName());

    private final List<String> systemLog = new ArrayList<>();
    private final List<String> applicationLog = new ArrayList<>();

    @Override
    public void log(Level level, String message) {
        LOG.info("ProvisionLogger system " + level + ": " + message);
        systemLog.add(level + ": " + message);
    }

    @Override
    public void logApplicationPackage(Level level, String message) {
        LOG.info("ProvisionLogger application " + level + ": " + message);
        applicationLog.add(level + ": " + message);
    }

    public List<String> systemLog() { return systemLog; }
    public List<String> applicationLog() { return applicationLog; }

}