Enforce checkstyle and findbug under PCE Api
[bgpcep.git] / pcep / testtool / src / test / java / org / opendaylight / protocol / pcep / testtool / SimpleSessionListener.java
1 /*
2  * Copyright (c) 2013 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.protocol.pcep.testtool;
9
10 import com.google.common.collect.Lists;
11 import java.util.List;
12 import org.opendaylight.protocol.pcep.PCEPSession;
13 import org.opendaylight.protocol.pcep.PCEPSessionListener;
14 import org.opendaylight.protocol.pcep.PCEPTerminationReason;
15 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.pcep.types.rev131005.Message;
16 import org.slf4j.Logger;
17 import org.slf4j.LoggerFactory;
18
19 /**
20  * Simple Session Listener that is notified about messages and changes in the session.
21  */
22 public class SimpleSessionListener implements PCEPSessionListener {
23
24     private List<Message> messages = Lists.newArrayList();
25
26     private static final Logger LOG = LoggerFactory.getLogger(SimpleSessionListener.class);
27
28     public SimpleSessionListener() {
29     }
30
31     @Override
32     public void onMessage(final PCEPSession session, final Message message) {
33         LOG.debug("Received message: {}", message);
34         this.messages.add(message);
35     }
36
37     @Override
38     public void onSessionUp(final PCEPSession session) {
39         LOG.debug("Session up.");
40     }
41
42     @Override
43     public void onSessionDown(final PCEPSession session, final Exception exception) {
44         LOG.debug("Session down with cause : {} or exception: {}", exception.getCause(), exception, exception);
45         try {
46             session.close();
47         } catch (Exception ie) {
48             LOG.warn("Error closing session", ie);
49         }
50     }
51
52     @Override
53     public void onSessionTerminated(final PCEPSession session, final PCEPTerminationReason cause) {
54         LOG.debug("Session terminated. Cause : {}", cause.toString());
55     }
56 }