Merge "Bug 1112: Update toaster to use async best practices"
[controller.git] / opendaylight / md-sal / sal-binding-dom-it / src / test / java / org / opendaylight / controller / sal / binding / test / bugfix / WriteParentListenAugmentTest.java
1 /*
2  * Copyright (c) 2014 Cisco Systems, Inc. and others.  All rights reserved.
3  *
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
7  */
8
9 package org.opendaylight.controller.sal.binding.test.bugfix;
10
11 import static org.junit.Assert.assertEquals;
12 import static org.junit.Assert.assertTrue;
13
14 import java.util.concurrent.TimeUnit;
15
16 import org.junit.Test;
17 import org.opendaylight.controller.md.sal.common.api.data.DataChangeEvent;
18 import org.opendaylight.controller.sal.binding.api.data.DataChangeListener;
19 import org.opendaylight.controller.sal.binding.api.data.DataModificationTransaction;
20 import org.opendaylight.controller.sal.binding.test.AbstractDataServiceTest;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.inventory.rev130819.FlowCapableNode;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.inventory.rev130819.FlowCapableNodeBuilder;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeId;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.Nodes;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.Node;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.NodeBuilder;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.NodeKey;
28 import org.opendaylight.yangtools.concepts.ListenerRegistration;
29 import org.opendaylight.yangtools.yang.binding.DataObject;
30 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
31
32 import com.google.common.util.concurrent.SettableFuture;
33
34 @SuppressWarnings("deprecation")
35 public class WriteParentListenAugmentTest extends AbstractDataServiceTest {
36
37     private static final String NODE_ID = "node:1";
38
39     private static final NodeKey NODE_KEY = new NodeKey(new NodeId(NODE_ID));
40     private static final InstanceIdentifier<Node> NODE_INSTANCE_ID_BA = InstanceIdentifier.builder(Nodes.class) //
41             .child(Node.class, NODE_KEY).toInstance();
42
43     private static final InstanceIdentifier<FlowCapableNode> AUGMENT_WILDCARDED_PATH = InstanceIdentifier
44             .builder(Nodes.class).child(Node.class).augmentation(FlowCapableNode.class).toInstance();
45
46     private static final InstanceIdentifier<FlowCapableNode> AUGMENT_NODE_PATH = InstanceIdentifier
47             .builder(Nodes.class).child(Node.class, NODE_KEY).augmentation(FlowCapableNode.class).toInstance();
48
49     @Test
50     public void writeNodeListenAugment() throws Exception {
51
52         final SettableFuture<DataChangeEvent<InstanceIdentifier<?>, DataObject>> event = SettableFuture.create();
53
54         ListenerRegistration<DataChangeListener> dclRegistration = baDataService.registerDataChangeListener(
55                 AUGMENT_WILDCARDED_PATH, new DataChangeListener() {
56
57                     @Override
58                     public void onDataChanged(final DataChangeEvent<InstanceIdentifier<?>, DataObject> change) {
59                         event.set(change);
60                     }
61                 });
62
63         DataModificationTransaction modification = baDataService.beginTransaction();
64
65         Node node = new NodeBuilder() //
66                 .setKey(NODE_KEY) //
67                 .addAugmentation(FlowCapableNode.class, flowCapableNode("one")).build();
68         modification.putOperationalData(NODE_INSTANCE_ID_BA, node);
69         modification.commit().get();
70
71         DataChangeEvent<InstanceIdentifier<?>, DataObject> receivedEvent = event.get(1000, TimeUnit.MILLISECONDS);
72         assertTrue(receivedEvent.getCreatedOperationalData().containsKey(AUGMENT_NODE_PATH));
73
74         dclRegistration.close();
75
76         DataModificationTransaction mod2 = baDataService.beginTransaction();
77         mod2.putOperationalData(AUGMENT_NODE_PATH, flowCapableNode("two"));
78         mod2.commit().get();
79
80         FlowCapableNode readedAug = (FlowCapableNode) baDataService.readOperationalData(AUGMENT_NODE_PATH);
81         assertEquals("two", readedAug.getDescription());
82
83     }
84
85     private FlowCapableNode flowCapableNode(final String description) {
86         return new FlowCapableNodeBuilder() //
87                 .setDescription(description) //
88                 .build();
89     }
90 }