2 * Copyright (c) 2017 Cisco Systems, Inc. and others. All rights reserved.
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
9 package org.opendaylight.controller.clustering.it.provider;
11 import com.google.common.util.concurrent.Futures;
12 import java.util.HashMap;
14 import java.util.concurrent.Future;
15 import org.opendaylight.controller.clustering.it.provider.impl.GetConstantService;
16 import org.opendaylight.controller.clustering.it.provider.impl.RoutedGetConstantService;
17 import org.opendaylight.controller.clustering.it.provider.impl.SingletonGetConstantService;
18 import org.opendaylight.controller.md.sal.binding.impl.BindingToNormalizedNodeCodec;
19 import org.opendaylight.controller.md.sal.binding.impl.BindingToNormalizedNodeCodecFactory;
20 import org.opendaylight.controller.md.sal.dom.api.DOMRpcImplementationRegistration;
21 import org.opendaylight.controller.md.sal.dom.api.DOMRpcProviderService;
22 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker;
23 import org.opendaylight.controller.sal.binding.api.RpcProviderRegistry;
24 import org.opendaylight.controller.sal.core.api.model.SchemaService;
25 import org.opendaylight.mdsal.binding.dom.codec.api.BindingNormalizedNodeSerializer;
26 import org.opendaylight.mdsal.binding.generator.impl.GeneratedClassLoadingStrategy;
27 import org.opendaylight.mdsal.singleton.common.api.ClusterSingletonServiceProvider;
28 import org.opendaylight.mdsal.singleton.common.api.ClusterSingletonServiceRegistration;
29 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.AddShardReplicaInput;
30 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.BecomeModuleLeaderInput;
31 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.BecomePrefixLeaderInput;
32 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.IsClientAbortedOutput;
33 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.OdlMdsalLowlevelControlService;
34 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.ProduceTransactionsInput;
35 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.PublishNotificationsInput;
36 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.RegisterBoundConstantInput;
37 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.RegisterConstantInput;
38 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.RegisterDefaultConstantInput;
39 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.RegisterSingletonConstantInput;
40 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.RemoveShardReplicaInput;
41 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.SubscribeYnlInput;
42 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.UnregisterBoundConstantInput;
43 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.UnregisterFlappingSingletonOutput;
44 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.UnsubscribeDdtlOutput;
45 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.UnsubscribeDtclOutput;
46 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.UnsubscribeYnlInput;
47 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.UnsubscribeYnlOutput;
48 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.WriteTransactionsInput;
49 import org.opendaylight.yangtools.concepts.ListenerRegistration;
50 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
51 import org.opendaylight.yangtools.yang.common.RpcError;
52 import org.opendaylight.yangtools.yang.common.RpcError.ErrorType;
53 import org.opendaylight.yangtools.yang.common.RpcResult;
54 import org.opendaylight.yangtools.yang.common.RpcResultBuilder;
55 import org.opendaylight.yangtools.yang.model.api.SchemaContextListener;
56 import org.slf4j.Logger;
57 import org.slf4j.LoggerFactory;
59 public class MdsalLowLevelTestProvider implements OdlMdsalLowlevelControlService {
61 private static final Logger LOG = LoggerFactory.getLogger(MdsalLowLevelTestProvider.class);
63 private final RpcProviderRegistry rpcRegistry;
64 private final BindingAwareBroker.RpcRegistration<OdlMdsalLowlevelControlService> registration;
65 private final BindingNormalizedNodeSerializer bindingNormalizedNodeSerializer;
66 private final SchemaService schemaService;
67 private final ClusterSingletonServiceProvider singletonService;
68 private final DOMRpcProviderService domRpcService;
70 private Map<InstanceIdentifier<?>, DOMRpcImplementationRegistration<RoutedGetConstantService>> routedRegistrations =
73 private DOMRpcImplementationRegistration<GetConstantService> globalGetConstantRegistration = null;
74 private ClusterSingletonServiceRegistration getSingletonConstantRegistration;
76 public MdsalLowLevelTestProvider(final RpcProviderRegistry rpcRegistry,
77 final DOMRpcProviderService domRpcService,
78 final ClusterSingletonServiceProvider singletonService,
79 final SchemaService schemaService,
80 final BindingNormalizedNodeSerializer bindingNormalizedNodeSerializer) {
81 this.rpcRegistry = rpcRegistry;
82 this.domRpcService = domRpcService;
83 this.singletonService = singletonService;
84 this.schemaService = schemaService;
85 this.bindingNormalizedNodeSerializer = bindingNormalizedNodeSerializer;
87 registration = rpcRegistry.addRpcImplementation(OdlMdsalLowlevelControlService.class, this);
91 public Future<RpcResult<Void>> unregisterSingletonConstant() {
92 LOG.debug("unregister-singleton-constant");
94 if (getSingletonConstantRegistration == null) {
95 LOG.debug("No get-singleton-constant registration present.");
96 final RpcError rpcError = RpcResultBuilder
97 .newError(ErrorType.APPLICATION, "missing-registration", "No get-singleton-constant rpc registration present.");
98 final RpcResult<Void> result = RpcResultBuilder.<Void>failed().withRpcError(rpcError).build();
99 return Futures.immediateFuture(result);
103 getSingletonConstantRegistration.close();
104 getSingletonConstantRegistration = null;
106 return Futures.immediateFuture(RpcResultBuilder.<Void>success().build());
107 } catch (final Exception e) {
108 LOG.debug("There was a problem closing the singleton constant service", e);
109 final RpcError rpcError = RpcResultBuilder
110 .newError(ErrorType.APPLICATION, "error-closing", "There was a problem closing get-singleton-constant");
111 final RpcResult<Void> result = RpcResultBuilder.<Void>failed().withRpcError(rpcError).build();
112 return Futures.immediateFuture(result);
117 public Future<RpcResult<Void>> publishNotifications(PublishNotificationsInput input) {
122 public Future<RpcResult<Void>> subscribeDtcl() {
127 public Future<RpcResult<Void>> writeTransactions(WriteTransactionsInput input) {
132 public Future<RpcResult<IsClientAbortedOutput>> isClientAborted() {
137 public Future<RpcResult<Void>> becomeModuleLeader(BecomeModuleLeaderInput input) {
142 public Future<RpcResult<Void>> removeShardReplica(RemoveShardReplicaInput input) {
147 public Future<RpcResult<Void>> subscribeYnl(SubscribeYnlInput input) {
152 public Future<RpcResult<Void>> becomePrefixLeader(BecomePrefixLeaderInput input) {
157 public Future<RpcResult<Void>> unregisterBoundConstant(final UnregisterBoundConstantInput input) {
158 LOG.debug("unregister-bound-constant, {}", input);
160 final DOMRpcImplementationRegistration<RoutedGetConstantService> registration =
161 routedRegistrations.remove(input.getContext());
163 if (registration == null) {
164 LOG.debug("No get-contexted-constant registration for context: {}", input.getContext());
165 final RpcError rpcError = RpcResultBuilder
166 .newError(ErrorType.APPLICATION, "missing-registration", "No get-constant rpc registration present.");
167 final RpcResult<Void> result = RpcResultBuilder.<Void>failed().withRpcError(rpcError).build();
168 return Futures.immediateFuture(result);
171 registration.close();
172 return Futures.immediateFuture(RpcResultBuilder.<Void>success().build());
176 public Future<RpcResult<Void>> registerSingletonConstant(final RegisterSingletonConstantInput input) {
178 LOG.debug("Received register-singleton-constant rpc, input: {}", input);
180 if (input.getConstant() == null) {
181 final RpcError error = RpcResultBuilder.newError(
182 ErrorType.RPC, "Invalid input.", "Constant value is null");
183 return Futures.immediateFuture(RpcResultBuilder.<Void>failed().withRpcError(error).build());
186 getSingletonConstantRegistration =
187 SingletonGetConstantService.registerNew(singletonService, domRpcService, input.getConstant());
189 return Futures.immediateFuture(RpcResultBuilder.<Void>success().build());
193 public Future<RpcResult<Void>> registerDefaultConstant(RegisterDefaultConstantInput input) {
198 public Future<RpcResult<Void>> unregisterConstant() {
200 if (globalGetConstantRegistration == null) {
201 final RpcError rpcError = RpcResultBuilder
202 .newError(ErrorType.APPLICATION, "missing-registration", "No get-constant rpc registration present.");
203 final RpcResult<Void> result = RpcResultBuilder.<Void>failed().withRpcError(rpcError).build();
204 return Futures.immediateFuture(result);
207 globalGetConstantRegistration.close();
208 globalGetConstantRegistration = null;
210 return Futures.immediateFuture(RpcResultBuilder.<Void>success().build());
214 public Future<RpcResult<UnregisterFlappingSingletonOutput>> unregisterFlappingSingleton() {
219 public Future<RpcResult<Void>> addShardReplica(AddShardReplicaInput input) {
224 public Future<RpcResult<Void>> subscribeDdtl() {
229 public Future<RpcResult<Void>> registerBoundConstant(final RegisterBoundConstantInput input) {
230 LOG.debug("register-bound-constant: {}", input);
232 if (input.getContext() == null) {
233 final RpcError error = RpcResultBuilder.newError(
234 ErrorType.RPC, "Invalid input.", "Context value is null");
235 return Futures.immediateFuture(RpcResultBuilder.<Void>failed().withRpcError(error).build());
238 if (input.getConstant() == null) {
239 final RpcError error = RpcResultBuilder.newError(
240 ErrorType.RPC, "Invalid input.", "Constant value is null");
241 return Futures.immediateFuture(RpcResultBuilder.<Void>failed().withRpcError(error).build());
244 if (routedRegistrations.containsKey(input.getContext())) {
245 final RpcError error = RpcResultBuilder.newError(ErrorType.RPC, "Registration present.",
246 "There is already a rpc registered for context: " + input.getContext());
247 return Futures.immediateFuture(RpcResultBuilder.<Void>failed().withRpcError(error).build());
250 final DOMRpcImplementationRegistration<RoutedGetConstantService> registration =
251 RoutedGetConstantService.registerNew(bindingNormalizedNodeSerializer, domRpcService,
252 input.getConstant(), input.getContext());
254 routedRegistrations.put(input.getContext(), registration);
255 return Futures.immediateFuture(RpcResultBuilder.<Void>success().build());
259 public Future<RpcResult<Void>> registerFlappingSingleton() {
264 public Future<RpcResult<UnsubscribeDtclOutput>> unsubscribeDtcl() {
269 public Future<RpcResult<Void>> deconfigureIdIntsShard() {
274 public Future<RpcResult<UnsubscribeYnlOutput>> unsubscribeYnl(UnsubscribeYnlInput input) {
279 public Future<RpcResult<Void>> produceTransactions(ProduceTransactionsInput input) {
284 public Future<RpcResult<Void>> registerConstant(final RegisterConstantInput input) {
286 LOG.debug("Received register-constant rpc, input: {}", input);
288 if (input.getConstant() == null) {
289 final RpcError error = RpcResultBuilder.newError(
290 ErrorType.RPC, "Invalid input.", "Constant value is null");
291 return Futures.immediateFuture(RpcResultBuilder.<Void>failed().withRpcError(error).build());
294 if (globalGetConstantRegistration != null) {
295 final RpcError error = RpcResultBuilder.newError(ErrorType.RPC, "Registration present.",
296 "There is already a get-constant rpc registered.");
297 return Futures.immediateFuture(RpcResultBuilder.<Void>failed().withRpcError(error).build());
300 globalGetConstantRegistration = GetConstantService.registerNew(domRpcService, input.getConstant());
301 return Futures.immediateFuture(RpcResultBuilder.<Void>success().build());
305 public Future<RpcResult<Void>> unregisterDefaultConstant() {
310 public Future<RpcResult<UnsubscribeDdtlOutput>> unsubscribeDdtl() {