Fix Logger use
[openflowjava.git] / openflow-protocol-impl / src / test / java / org / opendaylight / openflowjava / protocol / impl / util / OF13InstructionsSerializerTest.java
1 /*
2  * Copyright (c) 2013 Pantheon Technologies s.r.o. 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.openflowjava.protocol.impl.util;
9
10 import io.netty.buffer.ByteBuf;
11 import io.netty.buffer.UnpooledByteBufAllocator;
12
13 import java.util.ArrayList;
14 import java.util.List;
15
16 import org.junit.Assert;
17 import org.junit.Before;
18 import org.junit.Test;
19 import org.opendaylight.openflowjava.protocol.api.extensibility.SerializerRegistry;
20 import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
21 import org.opendaylight.openflowjava.protocol.impl.serialization.SerializerRegistryImpl;
22 import org.opendaylight.openflowjava.util.ByteBufUtils;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev150203.action.grouping.action.choice.OutputActionCaseBuilder;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev150203.action.grouping.action.choice.PopPbbCaseBuilder;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev150203.action.grouping.action.choice.PushVlanCaseBuilder;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev150203.action.grouping.action.choice.SetNwTtlCaseBuilder;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev150203.action.grouping.action.choice.output.action._case.OutputActionBuilder;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev150203.action.grouping.action.choice.push.vlan._case.PushVlanActionBuilder;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev150203.action.grouping.action.choice.set.nw.ttl._case.SetNwTtlActionBuilder;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev150203.actions.grouping.Action;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.action.rev150203.actions.grouping.ActionBuilder;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instruction.grouping.instruction.choice.ApplyActionsCaseBuilder;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instruction.grouping.instruction.choice.ClearActionsCaseBuilder;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instruction.grouping.instruction.choice.GotoTableCaseBuilder;
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instruction.grouping.instruction.choice.MeterCaseBuilder;
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instruction.grouping.instruction.choice.WriteActionsCaseBuilder;
37 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instruction.grouping.instruction.choice.WriteMetadataCaseBuilder;
38 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instruction.grouping.instruction.choice._goto.table._case.GotoTableBuilder;
39 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instruction.grouping.instruction.choice.apply.actions._case.ApplyActionsBuilder;
40 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instruction.grouping.instruction.choice.meter._case.MeterBuilder;
41 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instruction.grouping.instruction.choice.write.actions._case.WriteActionsBuilder;
42 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instruction.grouping.instruction.choice.write.metadata._case.WriteMetadataBuilder;
43 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instructions.grouping.Instruction;
44 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.instruction.rev130731.instructions.grouping.InstructionBuilder;
45 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.EtherType;
46 import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.PortNumber;
47
48 /**
49  * @author michal.polkorab
50  *
51  */
52 public class OF13InstructionsSerializerTest {
53
54     private SerializerRegistry registry;
55
56     /**
57      * Initializes serializer table and stores correct factory in field
58      */
59     @Before
60     public void startUp() {
61         registry = new SerializerRegistryImpl();
62         registry.init();
63     }
64
65     /**
66      * Testing instructions translation
67      */
68     @Test
69     public void test() {
70         List<Instruction> instructions = new ArrayList<>();
71         // Goto_table instruction
72         InstructionBuilder builder = new InstructionBuilder();
73         GotoTableCaseBuilder gotoCaseBuilder = new GotoTableCaseBuilder();
74         GotoTableBuilder instructionBuilder = new GotoTableBuilder();
75         instructionBuilder.setTableId((short) 5);
76         gotoCaseBuilder.setGotoTable(instructionBuilder.build());
77         builder.setInstructionChoice(gotoCaseBuilder.build());
78         instructions.add(builder.build());
79         // Write_metadata instruction
80         builder = new InstructionBuilder();
81         WriteMetadataCaseBuilder metadataCaseBuilder = new WriteMetadataCaseBuilder();
82         WriteMetadataBuilder metadataBuilder = new WriteMetadataBuilder();
83         metadataBuilder.setMetadata(ByteBufUtils.hexStringToBytes("00 01 02 03 04 05 06 07"));
84         metadataBuilder.setMetadataMask(ByteBufUtils.hexStringToBytes("07 06 05 04 03 02 01 00"));
85         metadataCaseBuilder.setWriteMetadata(metadataBuilder.build());
86         builder.setInstructionChoice(metadataCaseBuilder.build());
87         instructions.add(builder.build());
88         // Clear_actions instruction
89         builder = new InstructionBuilder();
90         builder.setInstructionChoice(new ClearActionsCaseBuilder().build());
91         instructions.add(builder.build());
92         // Meter instruction
93         builder = new InstructionBuilder();
94         MeterCaseBuilder meterCaseBuilder = new MeterCaseBuilder();
95         MeterBuilder meterBuilder = new MeterBuilder();
96         meterBuilder.setMeterId(42L);
97         meterCaseBuilder.setMeter(meterBuilder.build());
98         builder.setInstructionChoice(meterCaseBuilder.build());
99         instructions.add(builder.build());
100         // Write_actions instruction
101         builder = new InstructionBuilder();
102         WriteActionsCaseBuilder writeActionsCaseBuilder = new WriteActionsCaseBuilder();
103         WriteActionsBuilder writeActionsBuilder = new WriteActionsBuilder();
104         List<Action> actions = new ArrayList<>();
105         ActionBuilder actionBuilder = new ActionBuilder();
106         OutputActionCaseBuilder caseBuilder = new OutputActionCaseBuilder();
107         OutputActionBuilder outputBuilder = new OutputActionBuilder();
108         outputBuilder.setPort(new PortNumber(45L));
109         outputBuilder.setMaxLength(55);
110         caseBuilder.setOutputAction(outputBuilder.build());
111         actionBuilder.setActionChoice(caseBuilder.build());
112         actions.add(actionBuilder.build());
113         actionBuilder = new ActionBuilder();
114         SetNwTtlCaseBuilder ttlCaseBuilder = new SetNwTtlCaseBuilder();
115         SetNwTtlActionBuilder ttlActionBuilder = new SetNwTtlActionBuilder();
116         ttlActionBuilder.setNwTtl((short) 64);
117         ttlCaseBuilder.setSetNwTtlAction(ttlActionBuilder.build());
118         actionBuilder.setActionChoice(ttlCaseBuilder.build());
119         actions.add(actionBuilder.build());
120         writeActionsBuilder.setAction(actions);
121         writeActionsCaseBuilder.setWriteActions(writeActionsBuilder.build());
122         builder.setInstructionChoice(writeActionsCaseBuilder.build());
123         instructions.add(builder.build());
124         // Apply_actions instruction
125         builder = new InstructionBuilder();
126         ApplyActionsCaseBuilder applyActionsCaseBuilder = new ApplyActionsCaseBuilder();
127         ApplyActionsBuilder applyActionsBuilder = new ApplyActionsBuilder();
128         actions = new ArrayList<>();
129         actionBuilder = new ActionBuilder();
130         PushVlanCaseBuilder vlanCaseBuilder = new PushVlanCaseBuilder();
131         PushVlanActionBuilder vlanBuilder = new PushVlanActionBuilder();
132         vlanBuilder.setEthertype(new EtherType(new EtherType(14)));
133         vlanCaseBuilder.setPushVlanAction(vlanBuilder.build());
134         actionBuilder.setActionChoice(vlanCaseBuilder.build());
135         actions.add(actionBuilder.build());
136         actionBuilder = new ActionBuilder();
137         actionBuilder.setActionChoice(new PopPbbCaseBuilder().build());
138         actions.add(actionBuilder.build());
139         applyActionsBuilder.setAction(actions);
140         applyActionsCaseBuilder.setApplyActions(applyActionsBuilder.build());
141         builder.setInstructionChoice(applyActionsCaseBuilder.build());
142         instructions.add(builder.build());
143
144         ByteBuf out = UnpooledByteBufAllocator.DEFAULT.buffer();
145         ListSerializer.serializeList(instructions, TypeKeyMakerFactory
146                 .createInstructionKeyMaker(EncodeConstants.OF13_VERSION_ID), registry, out);
147
148         Assert.assertEquals("Wrong instruction type", 1, out.readUnsignedShort());
149         Assert.assertEquals("Wrong instruction length", 8, out.readUnsignedShort());
150         Assert.assertEquals("Wrong instruction table-id", 5, out.readUnsignedByte());
151         out.skipBytes(3);
152         Assert.assertEquals("Wrong instruction type", 2, out.readUnsignedShort());
153         Assert.assertEquals("Wrong instruction length", 24, out.readUnsignedShort());
154         out.skipBytes(4);
155         byte[] actual = new byte[8];
156         out.readBytes(actual);
157         Assert.assertEquals("Wrong instruction metadata", "00 01 02 03 04 05 06 07",
158                 ByteBufUtils.bytesToHexString(actual));
159         actual = new byte[8];
160         out.readBytes(actual);
161         Assert.assertEquals("Wrong instruction metadata-mask", "07 06 05 04 03 02 01 00",
162                 ByteBufUtils.bytesToHexString(actual));
163         Assert.assertEquals("Wrong instruction type", 5, out.readUnsignedShort());
164         Assert.assertEquals("Wrong instruction length", 8, out.readUnsignedShort());
165         out.skipBytes(4);
166         Assert.assertEquals("Wrong instruction type", 6, out.readUnsignedShort());
167         Assert.assertEquals("Wrong instruction length", 8, out.readUnsignedShort());
168         Assert.assertEquals("Wrong instruction meter-id", 42, out.readUnsignedInt());
169         Assert.assertEquals("Wrong instruction type", 3, out.readUnsignedShort());
170         Assert.assertEquals("Wrong instruction length", 32, out.readUnsignedShort());
171         out.skipBytes(4);
172         Assert.assertEquals("Wrong action type", 0, out.readUnsignedShort());
173         Assert.assertEquals("Wrong action length", 16, out.readUnsignedShort());
174         Assert.assertEquals("Wrong action type", 45, out.readUnsignedInt());
175         Assert.assertEquals("Wrong action type", 55, out.readUnsignedShort());
176         out.skipBytes(6);
177         Assert.assertEquals("Wrong action type", 23, out.readUnsignedShort());
178         Assert.assertEquals("Wrong action length", 8, out.readUnsignedShort());
179         Assert.assertEquals("Wrong action type", 64, out.readUnsignedByte());
180         out.skipBytes(3);
181         Assert.assertEquals("Wrong instruction type", 4, out.readUnsignedShort());
182         Assert.assertEquals("Wrong instruction length", 24, out.readUnsignedShort());
183         out.skipBytes(4);
184         Assert.assertEquals("Wrong action type", 17, out.readUnsignedShort());
185         Assert.assertEquals("Wrong action length", 8, out.readUnsignedShort());
186         Assert.assertEquals("Wrong action ethertype", 14, out.readUnsignedShort());
187         out.skipBytes(2);
188         Assert.assertEquals("Wrong action type", 27, out.readUnsignedShort());
189         Assert.assertEquals("Wrong action length", 8, out.readUnsignedShort());
190         out.skipBytes(4);
191         Assert.assertTrue("Not all data were read", out.readableBytes() == 0);
192     }
193
194 }