1 package org.opendaylight.controller.sal.binding.test.bugfix;
3 import java.util.Collections;
5 import java.util.concurrent.Callable;
6 import java.util.concurrent.ExecutorService;
7 import java.util.concurrent.Executors;
8 import java.util.concurrent.Future;
10 import javassist.ClassPool;
12 import org.junit.Ignore;
13 import org.junit.Test;
14 import org.opendaylight.controller.md.sal.common.api.TransactionStatus;
15 import org.opendaylight.controller.sal.binding.test.AbstractDataServiceTest;
16 import org.opendaylight.controller.sal.binding.test.util.BindingBrokerTestFactory;
17 import org.opendaylight.controller.sal.binding.api.data.DataModificationTransaction;
18 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.config.rev130819.flows.Flow;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.Node;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeId;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeRef;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.Nodes;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodesBuilder;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.NodeKey;
25 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
26 import org.opendaylight.yangtools.yang.common.QName;
27 import org.opendaylight.yangtools.yang.common.RpcResult;
28 import org.opendaylight.yangtools.yang.model.api.SchemaContext;
30 import com.google.common.util.concurrent.ListeningExecutorService;
31 import com.google.common.util.concurrent.MoreExecutors;
33 import static org.junit.Assert.*;
35 public class DOMCodecBug02Test extends AbstractDataServiceTest {
37 private static final QName NODE_ID_QNAME = QName.create(Node.QNAME, "id");
38 private static final String NODE_ID = "node:1";
40 private static final NodeKey NODE_KEY = new NodeKey(new NodeId(NODE_ID));
42 private static final Map<QName, Object> NODE_KEY_BI = Collections.<QName, Object> singletonMap(NODE_ID_QNAME,
45 private static final InstanceIdentifier<Nodes> NODES_INSTANCE_ID_BA = InstanceIdentifier.builder(Nodes.class) //
48 private static final org.opendaylight.yangtools.yang.data.api.InstanceIdentifier NODES_INSTANCE_ID_BI = //
49 org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.builder() //
53 private static final InstanceIdentifier<Node> NODE_INSTANCE_ID_BA = InstanceIdentifier.builder(Nodes.class) //
54 .child(Node.class, NODE_KEY).toInstance();
56 private static final org.opendaylight.yangtools.yang.data.api.InstanceIdentifier NODE_INSTANCE_ID_BI = //
57 org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.builder() //
59 .nodeWithKey(Node.QNAME, NODE_KEY_BI) //
61 private static final NodeRef NODE_REF = new NodeRef(NODE_INSTANCE_ID_BA);
64 * This test is ignored, till found out better way to test generation
65 * of classes without leaking of instances from previous run
71 ListeningExecutorService executor = MoreExecutors.sameThreadExecutor();
72 BindingBrokerTestFactory factory = new BindingBrokerTestFactory();
73 factory.setExecutor(executor);
74 factory.setClassPool(new ClassPool());
75 factory.setStartWithParsedSchema(getStartWithSchema());
76 testContext = factory.getTestContext();
79 baDataService = testContext.getBindingDataBroker();
80 biDataService = testContext.getDomDataBroker();
81 dataStore = testContext.getDomDataStore();
82 mappingService = testContext.getBindingToDomMappingService();
86 public void testSchemaContextNotAvailable() throws Exception {
88 ExecutorService testExecutor = Executors.newFixedThreadPool(1);
89 testContext.loadYangSchemaFromClasspath();
90 Future<Future<RpcResult<TransactionStatus>>> future = testExecutor.submit(new Callable<Future<RpcResult<TransactionStatus>>>() {
92 public Future<RpcResult<TransactionStatus>> call() throws Exception {
93 NodesBuilder nodesBuilder = new NodesBuilder();
94 nodesBuilder.setNode(Collections.<Node> emptyList());
95 DataModificationTransaction transaction = baDataService.beginTransaction();
96 transaction.putOperationalData(NODES_INSTANCE_ID_BA, nodesBuilder.build());
97 return transaction.commit();
102 RpcResult<TransactionStatus> result = future.get().get();
103 assertEquals(TransactionStatus.COMMITED, result.getResult());
105 Nodes nodes = checkForNodes();
106 assertNotNull(nodes);
110 private Nodes checkForNodes() {
111 return (Nodes) baDataService.readOperationalData(NODES_INSTANCE_ID_BA);
116 protected boolean getStartWithSchema() {