Add NetConfTopologyListenerTest
[transportpce.git] / networkmodel / src / test / java / org / opendaylight / transportpce / networkmodel / stub / MountPointStub.java
1 /*
2  * Copyright © 2018 Orange 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
9 package org.opendaylight.transportpce.networkmodel.stub;
10
11 import java.util.Optional;
12 import javax.annotation.Nonnull;
13 import org.eclipse.jdt.annotation.NonNull;
14 import org.opendaylight.mdsal.binding.api.BindingService;
15 import org.opendaylight.mdsal.binding.api.DataBroker;
16 import org.opendaylight.mdsal.binding.api.MountPoint;
17 import org.opendaylight.mdsal.binding.api.NotificationService;
18 import org.opendaylight.mdsal.binding.api.RpcConsumerRegistry;
19 import org.opendaylight.yangtools.concepts.ListenerRegistration;
20 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
21 import org.opendaylight.yangtools.yang.binding.NotificationListener;
22
23
24 public class MountPointStub implements MountPoint {
25
26     private DataBroker dataBroker;
27
28     private RpcConsumerRegistry rpcConsumerRegistry;
29
30
31     private NotificationService notificationService = new NotificationService() {
32         @Override
33         public @NonNull <T extends NotificationListener> ListenerRegistration<T>
34         registerNotificationListener(@NonNull T listener) {
35             return null;
36         }
37     };
38
39     public MountPointStub(DataBroker dataBroker) {
40         this.dataBroker = dataBroker;
41     }
42
43     public void setRpcConsumerRegistry(
44             RpcConsumerRegistry rpcConsumerRegistry) {
45         this.rpcConsumerRegistry = rpcConsumerRegistry;
46     }
47
48     @Override
49     @SuppressWarnings("unchecked")
50     public <T extends BindingService> Optional<T> getService(Class<T> service) {
51         if (service.isInstance(dataBroker)) {
52             return Optional.ofNullable((T) dataBroker);
53         }
54         if (service.isInstance(rpcConsumerRegistry)) {
55             return Optional.ofNullable((T) rpcConsumerRegistry);
56         }
57         if (service.isInstance(notificationService)) {
58             return Optional.ofNullable((T) notificationService);
59         }
60         return Optional.empty();
61     }
62
63     @Nonnull
64     @Override
65     public InstanceIdentifier<?> getIdentifier() {
66         throw new UnsupportedOperationException();
67     }
68 }