2 * Copyright (c) 2014 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
8 package org.opendaylight.controller.sal.binding.test.bugfix;
10 import static org.junit.Assert.assertEquals;
11 import static org.junit.Assert.assertNotNull;
13 import java.util.Collections;
15 import java.util.concurrent.Callable;
16 import java.util.concurrent.ExecutorService;
17 import java.util.concurrent.Executors;
18 import java.util.concurrent.Future;
20 import javassist.ClassPool;
22 import org.junit.Test;
23 import org.opendaylight.controller.md.sal.common.api.TransactionStatus;
24 import org.opendaylight.controller.sal.binding.api.data.DataModificationTransaction;
25 import org.opendaylight.controller.sal.binding.test.AbstractDataServiceTest;
26 import org.opendaylight.controller.sal.binding.test.util.BindingBrokerTestFactory;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeId;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeRef;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.Nodes;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodesBuilder;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.Node;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.NodeKey;
33 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
34 import org.opendaylight.yangtools.yang.common.QName;
35 import org.opendaylight.yangtools.yang.common.RpcResult;
37 import com.google.common.util.concurrent.ListeningExecutorService;
38 import com.google.common.util.concurrent.MoreExecutors;
40 public class DOMCodecBug02Test extends AbstractDataServiceTest {
42 private static final QName NODE_ID_QNAME = QName.create(Node.QNAME, "id");
43 private static final String NODE_ID = "node:1";
45 private static final NodeKey NODE_KEY = new NodeKey(new NodeId(NODE_ID));
47 private static final Map<QName, Object> NODE_KEY_BI = Collections.<QName, Object> singletonMap(NODE_ID_QNAME,
50 private static final InstanceIdentifier<Nodes> NODES_INSTANCE_ID_BA = InstanceIdentifier.builder(Nodes.class) //
53 private static final org.opendaylight.yangtools.yang.data.api.InstanceIdentifier NODES_INSTANCE_ID_BI = //
54 org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.builder() //
58 private static final InstanceIdentifier<Node> NODE_INSTANCE_ID_BA = InstanceIdentifier.builder(Nodes.class) //
59 .child(Node.class, NODE_KEY).toInstance();
61 private static final org.opendaylight.yangtools.yang.data.api.InstanceIdentifier NODE_INSTANCE_ID_BI = //
62 org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.builder() //
64 .nodeWithKey(Node.QNAME, NODE_KEY_BI) //
66 private static final NodeRef NODE_REF = new NodeRef(NODE_INSTANCE_ID_BA);
69 * This test is ignored, till found out better way to test generation
70 * of classes without leaking of instances from previous run
77 ListeningExecutorService executor = MoreExecutors.sameThreadExecutor();
78 BindingBrokerTestFactory factory = new BindingBrokerTestFactory();
79 factory.setExecutor(executor);
80 factory.setClassPool(new ClassPool());
81 factory.setStartWithParsedSchema(getStartWithSchema());
82 testContext = factory.getTestContext();
85 baDataService = testContext.getBindingDataBroker();
86 biDataService = testContext.getDomDataBroker();
87 dataStore = testContext.getDomDataStore();
88 mappingService = testContext.getBindingToDomMappingService();
92 public void testSchemaContextNotAvailable() throws Exception {
94 ExecutorService testExecutor = Executors.newFixedThreadPool(1);
95 testContext.loadYangSchemaFromClasspath();
96 Future<Future<RpcResult<TransactionStatus>>> future = testExecutor.submit(new Callable<Future<RpcResult<TransactionStatus>>>() {
98 public Future<RpcResult<TransactionStatus>> call() throws Exception {
99 NodesBuilder nodesBuilder = new NodesBuilder();
100 nodesBuilder.setNode(Collections.<Node> emptyList());
101 DataModificationTransaction transaction = baDataService.beginTransaction();
102 transaction.putOperationalData(NODES_INSTANCE_ID_BA, nodesBuilder.build());
103 return transaction.commit();
108 RpcResult<TransactionStatus> result = future.get().get();
109 assertEquals(TransactionStatus.COMMITED, result.getResult());
111 Nodes nodes = checkForNodes();
112 assertNotNull(nodes);
116 private Nodes checkForNodes() {
117 return (Nodes) baDataService.readOperationalData(NODES_INSTANCE_ID_BA);
122 protected boolean getStartWithSchema() {