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 java.util.Collections;
12 import java.util.concurrent.Callable;
13 import java.util.concurrent.ExecutorService;
14 import java.util.concurrent.Executors;
15 import java.util.concurrent.Future;
17 import javassist.ClassPool;
19 import org.junit.Ignore;
20 import org.junit.Test;
21 import org.opendaylight.controller.md.sal.common.api.TransactionStatus;
22 import org.opendaylight.controller.sal.binding.test.AbstractDataServiceTest;
23 import org.opendaylight.controller.sal.binding.test.util.BindingBrokerTestFactory;
24 import org.opendaylight.controller.sal.binding.api.data.DataModificationTransaction;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.config.rev130819.flows.Flow;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.Node;
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.NodeKey;
32 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
33 import org.opendaylight.yangtools.yang.common.QName;
34 import org.opendaylight.yangtools.yang.common.RpcResult;
35 import org.opendaylight.yangtools.yang.model.api.SchemaContext;
37 import com.google.common.util.concurrent.ListeningExecutorService;
38 import com.google.common.util.concurrent.MoreExecutors;
40 import static org.junit.Assert.*;
42 public class DOMCodecBug02Test extends AbstractDataServiceTest {
44 private static final QName NODE_ID_QNAME = QName.create(Node.QNAME, "id");
45 private static final String NODE_ID = "node:1";
47 private static final NodeKey NODE_KEY = new NodeKey(new NodeId(NODE_ID));
49 private static final Map<QName, Object> NODE_KEY_BI = Collections.<QName, Object> singletonMap(NODE_ID_QNAME,
52 private static final InstanceIdentifier<Nodes> NODES_INSTANCE_ID_BA = InstanceIdentifier.builder(Nodes.class) //
55 private static final org.opendaylight.yangtools.yang.data.api.InstanceIdentifier NODES_INSTANCE_ID_BI = //
56 org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.builder() //
60 private static final InstanceIdentifier<Node> NODE_INSTANCE_ID_BA = InstanceIdentifier.builder(Nodes.class) //
61 .child(Node.class, NODE_KEY).toInstance();
63 private static final org.opendaylight.yangtools.yang.data.api.InstanceIdentifier NODE_INSTANCE_ID_BI = //
64 org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.builder() //
66 .nodeWithKey(Node.QNAME, NODE_KEY_BI) //
68 private static final NodeRef NODE_REF = new NodeRef(NODE_INSTANCE_ID_BA);
71 * This test is ignored, till found out better way to test generation
72 * of classes without leaking of instances from previous run
78 ListeningExecutorService executor = MoreExecutors.sameThreadExecutor();
79 BindingBrokerTestFactory factory = new BindingBrokerTestFactory();
80 factory.setExecutor(executor);
81 factory.setClassPool(new ClassPool());
82 factory.setStartWithParsedSchema(getStartWithSchema());
83 testContext = factory.getTestContext();
86 baDataService = testContext.getBindingDataBroker();
87 biDataService = testContext.getDomDataBroker();
88 dataStore = testContext.getDomDataStore();
89 mappingService = testContext.getBindingToDomMappingService();
93 public void testSchemaContextNotAvailable() throws Exception {
95 ExecutorService testExecutor = Executors.newFixedThreadPool(1);
96 testContext.loadYangSchemaFromClasspath();
97 Future<Future<RpcResult<TransactionStatus>>> future = testExecutor.submit(new Callable<Future<RpcResult<TransactionStatus>>>() {
99 public Future<RpcResult<TransactionStatus>> call() throws Exception {
100 NodesBuilder nodesBuilder = new NodesBuilder();
101 nodesBuilder.setNode(Collections.<Node> emptyList());
102 DataModificationTransaction transaction = baDataService.beginTransaction();
103 transaction.putOperationalData(NODES_INSTANCE_ID_BA, nodesBuilder.build());
104 return transaction.commit();
109 RpcResult<TransactionStatus> result = future.get().get();
110 assertEquals(TransactionStatus.COMMITED, result.getResult());
112 Nodes nodes = checkForNodes();
113 assertNotNull(nodes);
117 private Nodes checkForNodes() {
118 return (Nodes) baDataService.readOperationalData(NODES_INSTANCE_ID_BA);
123 protected boolean getStartWithSchema() {