Bug-915: Adding static document generation.
[controller.git] / opendaylight / config / logback-config-loader / src / test / java / org / opendaylight / controller / logback / config / loader / test / TestAppender.java
1 /**
2  * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8 package org.opendaylight.controller.logback.config.loader.test;
9
10 import java.util.ArrayList;
11 import java.util.List;
12
13 import ch.qos.logback.classic.spi.LoggingEvent;
14 import ch.qos.logback.core.Appender;
15 import ch.qos.logback.core.Context;
16 import ch.qos.logback.core.LogbackException;
17 import ch.qos.logback.core.filter.Filter;
18 import ch.qos.logback.core.spi.FilterReply;
19 import ch.qos.logback.core.status.Status;
20
21 /**
22  * dummy appender for collecting log messages
23  *
24  * @param <E>
25  */
26 public class TestAppender<E> implements Appender<E> {
27
28     private boolean started;
29     private Context context;
30     private String name;
31
32     private static List<String> logRecord = new ArrayList<>();
33
34     @Override
35     public void start() {
36         started = true;
37     }
38
39     @Override
40     public void stop() {
41         started = false;
42     }
43
44     @Override
45     public boolean isStarted() {
46         return started;
47     }
48
49     @Override
50     public void setContext(Context context) {
51         this.context = context;
52     }
53
54     @Override
55     public Context getContext() {
56         return context;
57     }
58
59     @Override
60     public void addStatus(Status status) {
61         // TODO Auto-generated method stub
62     }
63
64     @Override
65     public void addInfo(String msg) {
66         // TODO Auto-generated method stub
67     }
68
69     @Override
70     public void addInfo(String msg, Throwable ex) {
71         // TODO Auto-generated method stub
72     }
73
74     @Override
75     public void addWarn(String msg) {
76         // TODO Auto-generated method stub
77     }
78
79     @Override
80     public void addWarn(String msg, Throwable ex) {
81         // TODO Auto-generated method stub
82     }
83
84     @Override
85     public void addError(String msg) {
86         // TODO Auto-generated method stub
87     }
88
89     @Override
90     public void addError(String msg, Throwable ex) {
91         // TODO Auto-generated method stub
92     }
93
94     @Override
95     public void addFilter(Filter<E> newFilter) {
96         // TODO Auto-generated method stub
97     }
98
99     @Override
100     public void clearAllFilters() {
101         // TODO Auto-generated method stub
102     }
103
104     @Override
105     public List<Filter<E>> getCopyOfAttachedFiltersList() {
106         // TODO Auto-generated method stub
107         return null;
108     }
109
110     @Override
111     public FilterReply getFilterChainDecision(E event) {
112         // TODO Auto-generated method stub
113         return null;
114     }
115
116     @Override
117     public String getName() {
118         return name;
119     }
120
121     @Override
122     public void doAppend(E event) throws LogbackException {
123         if (event instanceof LoggingEvent) {
124             LoggingEvent lEvent = (LoggingEvent) event;
125             logRecord.add(String.format("%s -> [%s] %s: %s", event.getClass()
126                     .getSimpleName(), lEvent.getLevel(),
127                     lEvent.getLoggerName(), lEvent.getMessage()));
128         } else {
129             logRecord.add(event.getClass() + " -> " + event.toString());
130         }
131     }
132
133     @Override
134     public void setName(String name) {
135         this.name = name;
136     }
137
138     /**
139      * @return the logRecord
140      */
141     public static List<String> getLogRecord() {
142         return logRecord;
143     }
144
145 }