use of org.openkilda.floodlight.api.request.IngressFlowSegmentRequest in project open-kilda by telstra.
the class SpeakerFlowSegmentRequestBuilderTest method useActualFlowEndpoint.
@Test
public void useActualFlowEndpoint() {
Switch srcSwitch = Switch.builder().switchId(SWITCH_1).build();
Switch destSwitch = Switch.builder().switchId(SWITCH_2).build();
// having flow stored in DB
Flow origin = buildFlow(srcSwitch, 1, 5, destSwitch, 2, 0, 0);
setSegmentsWithoutTransitSwitches(Objects.requireNonNull(origin.getForwardPath()), Objects.requireNonNull(origin.getReversePath()));
// then new set of paths are created
FlowPath goalForwardPath = buildFlowPath(origin, origin.getSrcSwitch(), origin.getDestSwitch(), new FlowSegmentCookie(FlowPathDirection.FORWARD, cookieFactory.next()));
FlowPath goalReversePath = buildFlowPath(origin, origin.getDestSwitch(), origin.getSrcSwitch(), new FlowSegmentCookie(FlowPathDirection.REVERSE, cookieFactory.next()));
setSegmentsWithTransitSwitches(goalForwardPath, goalReversePath);
// than new version of flow is created to fulfill update request
Flow goal = Flow.builder().flowId(origin.getFlowId()).srcSwitch(origin.getSrcSwitch()).srcPort(origin.getSrcPort()).srcVlan(// update
origin.getSrcVlan() + 10).destSwitch(origin.getDestSwitch()).destPort(origin.getDestPort()).destVlan(origin.getDestVlan()).bandwidth(origin.getBandwidth()).encapsulationType(origin.getEncapsulationType()).build();
// emulate db behaviour - flow will have "existing" paths after fetching it from DB
goal.setForwardPath(origin.getForwardPath());
goal.setReversePath(origin.getReversePath());
goal.addPaths(goalForwardPath, goalReversePath);
// then produce path segment request factories
List<FlowSegmentRequestFactory> commands = target.buildIngressOnly(COMMAND_CONTEXT, goal, goalForwardPath, goalReversePath, SpeakerRequestBuildContext.getEmpty());
boolean haveMatch = false;
for (FlowSegmentRequestFactory entry : commands) {
// search command for flow source side
if (SWITCH_1.equals(entry.getSwitchId())) {
haveMatch = true;
Assert.assertTrue(entry instanceof IngressFlowSegmentRequestFactory);
IngressFlowSegmentRequestFactory segment = (IngressFlowSegmentRequestFactory) entry;
IngressFlowSegmentRequest request = segment.makeInstallRequest(commandIdGenerator.generate());
Assert.assertEquals(goal.getSrcVlan(), request.getEndpoint().getOuterVlanId());
}
}
Assert.assertTrue(haveMatch);
}
use of org.openkilda.floodlight.api.request.IngressFlowSegmentRequest in project open-kilda by telstra.
the class SpeakerFlowSegmentRequestBuilderTest method verifyCommonIngressRequest.
private IngressFlowSegmentRequest verifyCommonIngressRequest(Flow flow, FlowPath path, FlowSegmentRequest rawRequest) {
assertThat("Should be egress segment request", rawRequest, instanceOf(IngressFlowSegmentRequest.class));
IngressFlowSegmentRequest request = (IngressFlowSegmentRequest) rawRequest;
assertEquals(flow.getFlowId(), request.getFlowId());
assertEquals(path.getCookie(), request.getCookie());
assertEquals(path.getSegments().get(0).getSrcPort(), (int) request.getIslPort());
if (0 < flow.getBandwidth()) {
MeterConfig config = new MeterConfig(path.getMeterId(), flow.getBandwidth());
assertEquals(config, request.getMeterConfig());
} else {
assertNull(request.getMeterConfig());
}
verifyVlanEncapsulation(flow, path, request.getEncapsulation());
return request;
}
use of org.openkilda.floodlight.api.request.IngressFlowSegmentRequest in project open-kilda by telstra.
the class SpeakerFlowSegmentRequestBuilderTest method verifyForwardIngressRequest.
private IngressFlowSegmentRequest verifyForwardIngressRequest(Flow flow, FlowSegmentRequest rawRequest) {
FlowPath path = Objects.requireNonNull(flow.getForwardPath());
IngressFlowSegmentRequest request = verifyCommonIngressRequest(flow, path, rawRequest);
assertEquals(flow.getSrcSwitchId(), request.getSwitchId());
FlowEndpoint endpoint = new FlowEndpoint(flow.getSrcSwitchId(), flow.getSrcPort(), flow.getSrcVlan());
assertEquals(endpoint, request.getEndpoint());
return request;
}
use of org.openkilda.floodlight.api.request.IngressFlowSegmentRequest in project open-kilda by telstra.
the class SpeakerFlowSegmentRequestBuilderTest method verifyReverseIngressRequest.
private IngressFlowSegmentRequest verifyReverseIngressRequest(Flow flow, FlowSegmentRequest rawRequest) {
FlowPath path = Objects.requireNonNull(flow.getReversePath());
IngressFlowSegmentRequest request = verifyCommonIngressRequest(flow, path, rawRequest);
assertEquals(flow.getDestSwitchId(), request.getSwitchId());
FlowEndpoint endpoint = new FlowEndpoint(flow.getDestSwitchId(), flow.getDestPort(), flow.getDestVlan());
assertEquals(endpoint, request.getEndpoint());
return request;
}
Aggregations