Merge "Get rid of legacy ref_ prefixes in configuration"
[controller.git] / opendaylight / md-sal / sal-binding-dom-it / src / test / java / org / opendaylight / controller / sal / binding / test / bugfix / DOMCodecBug02Test.java
1 package org.opendaylight.controller.sal.binding.test.bugfix;
2
3 import java.util.Collections;
4 import java.util.Map;
5 import java.util.concurrent.Callable;
6 import java.util.concurrent.ExecutorService;
7 import java.util.concurrent.Executors;
8 import java.util.concurrent.Future;
9
10 import javassist.ClassPool;
11
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;
29
30 import com.google.common.util.concurrent.ListeningExecutorService;
31 import com.google.common.util.concurrent.MoreExecutors;
32
33 import static org.junit.Assert.*;
34
35 public class DOMCodecBug02Test extends AbstractDataServiceTest {
36
37     private static final QName NODE_ID_QNAME = QName.create(Node.QNAME, "id");
38     private static final String NODE_ID = "node:1";
39
40     private static final NodeKey NODE_KEY = new NodeKey(new NodeId(NODE_ID));
41
42     private static final Map<QName, Object> NODE_KEY_BI = Collections.<QName, Object> singletonMap(NODE_ID_QNAME,
43             NODE_ID);
44
45     private static final InstanceIdentifier<Nodes> NODES_INSTANCE_ID_BA = InstanceIdentifier.builder(Nodes.class) //
46             .toInstance();
47
48     private static final org.opendaylight.yangtools.yang.data.api.InstanceIdentifier NODES_INSTANCE_ID_BI = //
49     org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.builder() //
50             .node(Nodes.QNAME) //
51             .toInstance();
52
53     private static final InstanceIdentifier<Node> NODE_INSTANCE_ID_BA = InstanceIdentifier.builder(Nodes.class) //
54             .child(Node.class, NODE_KEY).toInstance();
55
56     private static final org.opendaylight.yangtools.yang.data.api.InstanceIdentifier NODE_INSTANCE_ID_BI = //
57     org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.builder() //
58             .node(Nodes.QNAME) //
59             .nodeWithKey(Node.QNAME, NODE_KEY_BI) //
60             .toInstance();
61     private static final NodeRef NODE_REF = new NodeRef(NODE_INSTANCE_ID_BA);
62
63     /**
64      * This test is ignored, till found out better way to test generation
65      * of classes without leaking of instances from previous run
66      * 
67      * @throws Exception
68      */
69     
70     public void setUp() {
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();
77         testContext.start();
78         
79         baDataService = testContext.getBindingDataBroker();
80         biDataService = testContext.getDomDataBroker();
81         dataStore = testContext.getDomDataStore();
82         mappingService = testContext.getBindingToDomMappingService();
83     };
84     
85     @Test
86     public void testSchemaContextNotAvailable() throws Exception {
87
88         ExecutorService testExecutor = Executors.newFixedThreadPool(1);
89         testContext.loadYangSchemaFromClasspath();
90         Future<Future<RpcResult<TransactionStatus>>> future = testExecutor.submit(new Callable<Future<RpcResult<TransactionStatus>>>() {
91             @Override
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();
98             }
99         });
100         
101         
102         RpcResult<TransactionStatus> result = future.get().get();
103         assertEquals(TransactionStatus.COMMITED, result.getResult());
104         
105         Nodes nodes = checkForNodes();
106         assertNotNull(nodes);
107
108     }
109
110     private Nodes checkForNodes() {
111         return (Nodes) baDataService.readOperationalData(NODES_INSTANCE_ID_BA);
112
113     }
114     
115     @Override
116     protected boolean getStartWithSchema() {
117         return false;
118     }
119
120 }