76869647002162deec3cbf6061676b7afb3fc7ce
[openflowplugin.git] / openflowplugin-impl / src / test / java / org / opendaylight / openflowplugin / impl / services / batch / FlatBatchGroupAdaptersTest.java
1 /*
2  * Copyright (c) 2016 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 package org.opendaylight.openflowplugin.impl.services.batch;
9
10 import com.google.common.collect.Lists;
11 import java.util.Iterator;
12 import org.junit.Assert;
13 import org.junit.Test;
14 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.ProcessFlatBatchOutput;
15 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.process.flat.batch.input.batch.batch.choice.flat.batch.add.group._case.FlatBatchAddGroup;
16 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.process.flat.batch.input.batch.batch.choice.flat.batch.add.group._case.FlatBatchAddGroupBuilder;
17 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.process.flat.batch.input.batch.batch.choice.flat.batch.remove.group._case.FlatBatchRemoveGroup;
18 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.process.flat.batch.input.batch.batch.choice.flat.batch.remove.group._case.FlatBatchRemoveGroupBuilder;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.process.flat.batch.input.batch.batch.choice.flat.batch.update.group._case.FlatBatchUpdateGroup;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.process.flat.batch.input.batch.batch.choice.flat.batch.update.group._case.FlatBatchUpdateGroupBuilder;
21 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.process.flat.batch.output.BatchFailure;
22 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.process.flat.batch.output.BatchFailureBuilder;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.process.flat.batch.output.batch.failure.batch.item.id.choice.FlatBatchFailureGroupIdCase;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.process.flat.batch.output.batch.failure.batch.item.id.choice.FlatBatchFailureGroupIdCaseBuilder;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.group.types.rev131018.GroupId;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.groups.service.rev160315.AddGroupsBatchInput;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.groups.service.rev160315.AddGroupsBatchOutputBuilder;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.groups.service.rev160315.BatchGroupOutputListGrouping;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.groups.service.rev160315.RemoveGroupsBatchInput;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.groups.service.rev160315.UpdateGroupsBatchInput;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.groups.service.rev160315.add.groups.batch.input.BatchAddGroups;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.groups.service.rev160315.batch.group.input.update.grouping.OriginalBatchedGroupBuilder;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.groups.service.rev160315.batch.group.input.update.grouping.UpdatedBatchedGroupBuilder;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.groups.service.rev160315.batch.group.output.list.grouping.BatchFailedGroupsOutput;
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.groups.service.rev160315.batch.group.output.list.grouping.BatchFailedGroupsOutputBuilder;
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.groups.service.rev160315.remove.groups.batch.input.BatchRemoveGroups;
37 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeId;
38 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeRef;
39 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.Nodes;
40 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.Node;
41 import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.nodes.NodeKey;
42 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
43 import org.opendaylight.yangtools.yang.common.RpcError;
44 import org.opendaylight.yangtools.yang.common.RpcResult;
45 import org.opendaylight.yangtools.yang.common.RpcResultBuilder;
46 import org.opendaylight.yangtools.yang.common.Uint16;
47 import org.opendaylight.yangtools.yang.common.Uint32;
48
49 /**
50  * Test for {@link FlatBatchGroupAdapters}.
51  */
52 public class FlatBatchGroupAdaptersTest {
53
54     private static final NodeId NODE_ID = new NodeId("ut-node-id");
55     private static final InstanceIdentifier<Node> NODE_II = InstanceIdentifier.create(Nodes.class)
56             .child(Node.class, new NodeKey(NODE_ID));
57     private static final NodeRef NODE_REF = new NodeRef(NODE_II);
58
59     @Test
60     public void testAdaptFlatBatchAddGroup() {
61         final BatchPlanStep planStep = new BatchPlanStep(BatchStepType.FLOW_ADD);
62         planStep.setBarrierAfter(true);
63         planStep.getTaskBag().addAll(Lists.newArrayList(
64                 createAddGroupBatch(Uint32.ONE),
65                 createAddGroupBatch(Uint32.TWO)));
66
67         final AddGroupsBatchInput addGroupsBatchInput =
68                 FlatBatchGroupAdapters.adaptFlatBatchAddGroup(planStep, NODE_REF);
69         Iterator<BatchAddGroups> iterator = addGroupsBatchInput.nonnullBatchAddGroups().values().iterator();
70
71         Assert.assertTrue(addGroupsBatchInput.isBarrierAfter());
72         Assert.assertEquals(2, addGroupsBatchInput.getBatchAddGroups().size());
73         Assert.assertEquals(1L, iterator.next().getGroupId().getValue().longValue());
74         Assert.assertEquals(2L, iterator.next().getGroupId().getValue().longValue());
75     }
76
77     private static FlatBatchAddGroup createAddGroupBatch(final Uint32 groupIdValue) {
78         return new FlatBatchAddGroupBuilder()
79                 .setGroupId(new GroupId(groupIdValue))
80                 .setBatchOrder(groupIdValue.toUint16())
81                 .build();
82     }
83
84     private static FlatBatchRemoveGroup createRemoveGroupBatch(final Uint32 groupIdValue) {
85         return new FlatBatchRemoveGroupBuilder()
86                 .setGroupId(new GroupId(groupIdValue))
87                 .setBatchOrder(groupIdValue.toUint16())
88                 .build();
89     }
90
91     private static FlatBatchUpdateGroup createUpdateGroupBatch(final Uint32 groupIdValue) {
92         return new FlatBatchUpdateGroupBuilder()
93                 .setOriginalBatchedGroup(new OriginalBatchedGroupBuilder()
94                         .setGroupId(new GroupId(groupIdValue))
95                         .build())
96                 .setUpdatedBatchedGroup(new UpdatedBatchedGroupBuilder()
97                         .setGroupId(new GroupId(groupIdValue))
98                         .build())
99                 .setBatchOrder(groupIdValue.toUint16())
100                 .build();
101     }
102
103     @Test
104     public void testAdaptFlatBatchRemoveGroup() {
105         final BatchPlanStep planStep = new BatchPlanStep(BatchStepType.FLOW_REMOVE);
106         planStep.setBarrierAfter(true);
107         planStep.getTaskBag().addAll(Lists.newArrayList(
108                 createRemoveGroupBatch(Uint32.ONE),
109                 createRemoveGroupBatch(Uint32.TWO)));
110
111         final RemoveGroupsBatchInput removeGroupsBatchInput =
112                 FlatBatchGroupAdapters.adaptFlatBatchRemoveGroup(planStep, NODE_REF);
113         Iterator<BatchRemoveGroups> iterator = removeGroupsBatchInput.nonnullBatchRemoveGroups().values().iterator();
114
115         Assert.assertTrue(removeGroupsBatchInput.isBarrierAfter());
116         Assert.assertEquals(2, removeGroupsBatchInput.getBatchRemoveGroups().size());
117         Assert.assertEquals(1L, iterator.next().getGroupId().getValue().longValue());
118         Assert.assertEquals(2L, iterator.next().getGroupId().getValue().longValue());
119     }
120
121     @Test
122     public void testAdaptFlatBatchUpdateGroup() {
123         final BatchPlanStep planStep = new BatchPlanStep(BatchStepType.FLOW_UPDATE);
124         planStep.setBarrierAfter(true);
125         planStep.getTaskBag().addAll(Lists.newArrayList(
126                 createUpdateGroupBatch(Uint32.ONE),
127                 createUpdateGroupBatch(Uint32.TWO)));
128
129         final UpdateGroupsBatchInput updateGroupsBatchInput =
130                 FlatBatchGroupAdapters.adaptFlatBatchUpdateGroup(planStep, NODE_REF);
131
132         Assert.assertTrue(updateGroupsBatchInput.isBarrierAfter());
133         Assert.assertEquals(2, updateGroupsBatchInput.getBatchUpdateGroups().size());
134         Assert.assertEquals(1L, updateGroupsBatchInput.getBatchUpdateGroups().get(0)
135                 .getUpdatedBatchedGroup().getGroupId().getValue().longValue());
136         Assert.assertEquals(2L, updateGroupsBatchInput.getBatchUpdateGroups().get(1)
137                 .getUpdatedBatchedGroup().getGroupId().getValue().longValue());
138     }
139
140     @Test
141     public void testCreateBatchGroupChainingFunction_failures() {
142         final RpcResult<BatchGroupOutputListGrouping> input = RpcResultBuilder.<BatchGroupOutputListGrouping>failed()
143                 .withError(RpcError.ErrorType.APPLICATION, "ut-groupError")
144                 .withResult(new AddGroupsBatchOutputBuilder()
145                         .setBatchFailedGroupsOutput(Lists.newArrayList(
146                                 createBatchFailedGroupsOutput(Uint16.ZERO, Uint32.ONE),
147                                 createBatchFailedGroupsOutput(Uint16.ONE, Uint32.TWO)
148                         ))
149                         .build())
150                 .build();
151
152         final RpcResult<ProcessFlatBatchOutput> rpcResult = FlatBatchGroupAdapters
153                 .convertBatchGroupResult(3).apply(input);
154         Iterator<BatchFailure> iterator = rpcResult.getResult().nonnullBatchFailure().values().iterator();
155
156         Assert.assertFalse(rpcResult.isSuccessful());
157         Assert.assertEquals(1, rpcResult.getErrors().size());
158         Assert.assertEquals(2, rpcResult.getResult().nonnullBatchFailure().size());
159         Assert.assertEquals(3, iterator.next().getBatchOrder().intValue());
160         BatchFailure secondBatchFailure = iterator.next();
161         Assert.assertEquals(4, secondBatchFailure.getBatchOrder().intValue());
162         Assert.assertEquals(2L, ((FlatBatchFailureGroupIdCase) secondBatchFailure
163                 .getBatchItemIdChoice()).getGroupId().getValue().longValue());
164     }
165
166     @Test
167     public void testCreateBatchGroupChainingFunction_successes() {
168         final RpcResult<BatchGroupOutputListGrouping> input = RpcResultBuilder
169                 .<BatchGroupOutputListGrouping>success(new AddGroupsBatchOutputBuilder().build())
170                 .build();
171
172         final RpcResult<ProcessFlatBatchOutput> rpcResult = FlatBatchGroupAdapters
173                 .convertBatchGroupResult(0).apply(input);
174
175         Assert.assertTrue(rpcResult.isSuccessful());
176         Assert.assertEquals(0, rpcResult.getErrors().size());
177         Assert.assertEquals(0, rpcResult.getResult().nonnullBatchFailure().size());
178     }
179
180     private static BatchFailedGroupsOutput createBatchFailedGroupsOutput(final Uint16 batchOrder,
181             final Uint32 groupIdValue) {
182         return new BatchFailedGroupsOutputBuilder()
183                 .setGroupId(new GroupId(groupIdValue))
184                 .setBatchOrder(batchOrder)
185                 .build();
186     }
187
188     private static BatchFailure createChainFailure(final Uint16 batchOrder, final Uint32 groupIdValue) {
189         return new BatchFailureBuilder()
190                 .setBatchOrder(batchOrder)
191                 .setBatchItemIdChoice(new FlatBatchFailureGroupIdCaseBuilder()
192                         .setGroupId(new GroupId(groupIdValue))
193                         .build())
194                 .build();
195     }
196 }