use of org.openkilda.rulemanager.SpeakerData in project open-kilda by telstra.
the class TablePassThroughDefaultRuleGeneratorTest method shouldBuildCorrectRuleForOf13.
@Test
public void shouldBuildCorrectRuleForOf13() {
Switch sw = buildSwitch("OF_13", Collections.emptySet());
TablePassThroughDefaultRuleGenerator generator = TablePassThroughDefaultRuleGenerator.builder().cookie(new Cookie(MULTITABLE_EGRESS_PASS_THROUGH_COOKIE)).tableId(OfTable.EGRESS).goToTableId(OfTable.TRANSIT).build();
List<SpeakerData> commands = generator.generateCommands(sw);
assertEquals(1, commands.size());
FlowSpeakerData flowCommandData = getCommand(FlowSpeakerData.class, commands);
assertEquals(sw.getSwitchId(), flowCommandData.getSwitchId());
assertEquals(sw.getOfVersion(), flowCommandData.getOfVersion().toString());
assertTrue(flowCommandData.getDependsOn().isEmpty());
assertEquals(new Cookie(MULTITABLE_EGRESS_PASS_THROUGH_COOKIE), flowCommandData.getCookie());
assertEquals(OfTable.EGRESS, flowCommandData.getTable());
assertEquals(MINIMAL_POSITIVE_PRIORITY, flowCommandData.getPriority());
assertTrue(flowCommandData.getMatch().isEmpty());
Instructions instructions = flowCommandData.getInstructions();
assertNull(instructions.getApplyActions());
assertNull(instructions.getWriteActions());
assertNull(instructions.getGoToMeter());
assertEquals(OfTable.TRANSIT, instructions.getGoToTable());
}
use of org.openkilda.rulemanager.SpeakerData in project open-kilda by telstra.
the class SingleTableIngressYRuleGeneratorTest method buildCommandsVlanEncapsulationSingleVlanTest.
@Test
public void buildCommandsVlanEncapsulationSingleVlanTest() {
Flow flow = buildFlow(PATH, OUTER_VLAN_ID_1, 0);
SingleTableIngressYRuleGenerator generator = buildGenerator(PATH, flow, VLAN_ENCAPSULATION);
List<SpeakerData> commands = generator.generateCommands(SWITCH_1);
assertEquals(2, commands.size());
FlowSpeakerData ingressCommand = (FlowSpeakerData) commands.get(0);
MeterSpeakerData meterCommand = (MeterSpeakerData) commands.get(1);
assertEquals(newArrayList(meterCommand.getUuid()), new ArrayList<>(ingressCommand.getDependsOn()));
Set<FieldMatch> expectedIngressMatch = Sets.newHashSet(FieldMatch.builder().field(Field.IN_PORT).value(PORT_NUMBER_1).build(), FieldMatch.builder().field(Field.VLAN_VID).value(OUTER_VLAN_ID_1).build());
List<Action> expectedIngressActions = newArrayList(SetFieldAction.builder().field(Field.VLAN_VID).value(TRANSIT_VLAN_ID).build(), new PortOutAction(new PortNumber(PORT_NUMBER_2)));
assertIngressCommand(ingressCommand, Priority.Y_FLOW_PRIORITY, expectedIngressMatch, expectedIngressActions, SHARED_METER_ID);
assertMeterCommand(meterCommand);
}
use of org.openkilda.rulemanager.SpeakerData in project open-kilda by telstra.
the class FlowLoopIngressRuleGeneratorTest method buildRulesForLoopLessFlowTest.
@Test
public void buildRulesForLoopLessFlowTest() {
Flow flow = buildFlow(PATH, 0, 0, 0, 0);
flow.setLoopSwitchId(null);
List<SpeakerData> commands = buildGenerator(flow, false).generateCommands(SWITCH_1);
assertEquals(0, commands.size());
}
use of org.openkilda.rulemanager.SpeakerData in project open-kilda by telstra.
the class FlowLoopIngressRuleGeneratorTest method buildSingleTableSingleVlanRuleTest.
@Test
public void buildSingleTableSingleVlanRuleTest() {
Flow flow = buildFlow(PATH, OUTER_VLAN_1, 0, OUTER_VLAN_2, 0);
List<SpeakerData> commands = buildGenerator(flow, false).generateCommands(SWITCH_1);
assertIngressCommands(commands, OfTable.INPUT, Priority.LOOP_FLOW_PRIORITY, newHashSet(FieldMatch.builder().field(Field.IN_PORT).value(PORT_NUMBER_1).build(), FieldMatch.builder().field(Field.VLAN_VID).value(OUTER_VLAN_1).build()), newArrayList(new PortOutAction(new PortNumber(SpecialPortType.IN_PORT))));
}
use of org.openkilda.rulemanager.SpeakerData in project open-kilda by telstra.
the class FlowLoopIngressRuleGeneratorTest method buildMultiTableDefaultFlowRuleTest.
@Test
public void buildMultiTableDefaultFlowRuleTest() {
Flow flow = buildFlow(PATH, 0, 0, OUTER_VLAN_2, INNER_VLAN_2);
List<SpeakerData> commands = buildGenerator(flow, true).generateCommands(SWITCH_1);
assertIngressCommands(commands, OfTable.INGRESS, Priority.LOOP_DEFAULT_FLOW_PRIORITY, newHashSet(FieldMatch.builder().field(Field.IN_PORT).value(PORT_NUMBER_1).build()), newArrayList(new PortOutAction(new PortNumber(SpecialPortType.IN_PORT))));
}
Aggregations