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 org.junit.Test;
21 import org.opendaylight.controller.md.sal.common.api.TransactionStatus;
22 import org.opendaylight.controller.sal.binding.api.data.DataModificationTransaction;
23 import org.opendaylight.controller.sal.binding.test.AbstractDataServiceTest;
24 import org.opendaylight.controller.sal.binding.test.util.BindingBrokerTestFactory;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeId;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeRef;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.Nodes;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodesBuilder;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.Node;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.NodeKey;
31 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
32 import org.opendaylight.yangtools.yang.common.QName;
33 import org.opendaylight.yangtools.yang.common.RpcResult;
35 import com.google.common.util.concurrent.ListeningExecutorService;
36 import com.google.common.util.concurrent.MoreExecutors;
38 public class DOMCodecBug02Test extends AbstractDataServiceTest {
40 private static final QName NODE_ID_QNAME = QName.create(Node.QNAME, "id");
41 private static final String NODE_ID = "node:1";
43 private static final NodeKey NODE_KEY = new NodeKey(new NodeId(NODE_ID));
45 private static final Map<QName, Object> NODE_KEY_BI = Collections.<QName, Object> singletonMap(NODE_ID_QNAME,
48 private static final InstanceIdentifier<Nodes> NODES_INSTANCE_ID_BA = InstanceIdentifier.builder(Nodes.class) //
51 private static final org.opendaylight.yangtools.yang.data.api.InstanceIdentifier NODES_INSTANCE_ID_BI = //
52 org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.builder() //
56 private static final InstanceIdentifier<Node> NODE_INSTANCE_ID_BA = InstanceIdentifier.builder(Nodes.class) //
57 .child(Node.class, NODE_KEY).toInstance();
59 private static final org.opendaylight.yangtools.yang.data.api.InstanceIdentifier NODE_INSTANCE_ID_BI = //
60 org.opendaylight.yangtools.yang.data.api.InstanceIdentifier.builder() //
62 .nodeWithKey(Node.QNAME, NODE_KEY_BI) //
64 private static final NodeRef NODE_REF = new NodeRef(NODE_INSTANCE_ID_BA);
67 * This test is ignored, till found out better way to test generation of
68 * classes without leaking of instances from previous run
75 ListeningExecutorService executor = MoreExecutors.sameThreadExecutor();
76 BindingBrokerTestFactory factory = new BindingBrokerTestFactory();
77 factory.setExecutor(executor);
78 factory.setStartWithParsedSchema(getStartWithSchema());
79 testContext = factory.getTestContext();
82 baDataService = testContext.getBindingDataBroker();
83 biDataService = testContext.getDomDataBroker();
84 dataStore = testContext.getDomDataStore();
85 mappingService = testContext.getBindingToDomMappingService();
89 public void testSchemaContextNotAvailable() throws Exception {
91 ExecutorService testExecutor = Executors.newFixedThreadPool(1);
92 testContext.loadYangSchemaFromClasspath();
93 Future<Future<RpcResult<TransactionStatus>>> future = testExecutor
94 .submit(new Callable<Future<RpcResult<TransactionStatus>>>() {
96 public Future<RpcResult<TransactionStatus>> call() throws Exception {
97 NodesBuilder nodesBuilder = new NodesBuilder();
98 nodesBuilder.setNode(Collections.<Node> emptyList());
99 DataModificationTransaction transaction = baDataService.beginTransaction();
100 transaction.putOperationalData(NODES_INSTANCE_ID_BA, nodesBuilder.build());
101 return transaction.commit();
105 RpcResult<TransactionStatus> result = future.get().get();
106 assertEquals(TransactionStatus.COMMITED, result.getResult());
108 Nodes nodes = checkForNodes();
109 assertNotNull(nodes);
113 private Nodes checkForNodes() {
114 return (Nodes) baDataService.readOperationalData(NODES_INSTANCE_ID_BA);
119 protected boolean getStartWithSchema() {