import org.opendaylight.openflowplugin.api.openflow.device.Xid;
import org.opendaylight.openflowplugin.impl.role.RoleChangeException;
import org.opendaylight.openflowplugin.impl.services.util.ServiceException;
+import org.opendaylight.openflowplugin.impl.util.ErrorUtil;
import org.opendaylight.yang.gen.v1.urn.opendaylight.flow.transaction.rev150304.TransactionId;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.ControllerRole;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.OfHeader;
} else {
LOG.error("getGenerationIdFromDevice RPC error " +
roleRequestOutputRpcResult.getErrors().iterator().next().getInfo());
-
+ finalFuture.setException(new RoleChangeException(ErrorUtil.errorsToString(roleRequestOutputRpcResult.getErrors())));
}
-
}
@Override
import com.google.common.util.concurrent.SettableFuture;
import java.math.BigInteger;
import java.util.concurrent.Future;
-import java.util.concurrent.Semaphore;
-import javax.annotation.concurrent.GuardedBy;
import org.opendaylight.openflowplugin.api.openflow.connection.ConnectionContext.CONNECTION_STATE;
import org.opendaylight.openflowplugin.api.openflow.device.DeviceContext;
import org.opendaylight.openflowplugin.api.openflow.device.RequestContextStack;
import org.opendaylight.openflowplugin.impl.services.AbstractSimpleService;
import org.opendaylight.openflowplugin.impl.services.RoleService;
import org.opendaylight.openflowplugin.impl.services.util.ServiceException;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.ErrorType;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.OfHeader;
import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.protocol.rev130731.RoleRequestOutput;
import org.opendaylight.yang.gen.v1.urn.opendaylight.role.service.rev150727.OfpRole;
import org.opendaylight.yang.gen.v1.urn.opendaylight.role.service.rev150727.SalRoleService;
import org.opendaylight.yang.gen.v1.urn.opendaylight.role.service.rev150727.SetRoleInput;
import org.opendaylight.yang.gen.v1.urn.opendaylight.role.service.rev150727.SetRoleOutput;
+import org.opendaylight.yangtools.yang.common.RpcError;
import org.opendaylight.yangtools.yang.common.RpcResult;
import org.opendaylight.yangtools.yang.common.RpcResultBuilder;
import org.slf4j.Logger;
private static final int MAX_RETRIES = 42;
+ private static final String ROLE_REQUEST_UNSUPPORTED = ErrorType.ROLEREQUESTFAILED.name().concat(" code UNSUP");
+
private final DeviceContext deviceContext;
private final RoleService roleService;
LOG.debug("setRoleOutput received after roleChangeTask execution:{}", result);
future.set(RpcResultBuilder.<SetRoleOutput> success().withResult(result.getResult()).build());
} else {
- LOG.error("setRole() failed with errors, will retry: {} times.", MAX_RETRIES - retryCounter);
- repeaterForChangeRole(future, input, (retryCounter + 1));
+ final boolean present = result
+ .getErrors()
+ .stream()
+ .anyMatch(rpcError -> (rpcError.getMessage().contains(ROLE_REQUEST_UNSUPPORTED)));
+
+ if (!present) {
+ LOG.warn("setRole() failed with errors, will retry: {} times.", MAX_RETRIES - retryCounter);
+ repeaterForChangeRole(future, input, (retryCounter + 1));
+ } else {
+ LOG.warn("setRole() failed with error - role request unsupported.");
+ future.set(result);
+ }
}
}
@Override
public void onFailure(final Throwable t) {
- LOG.error("Exception in setRole(), will retry: {} times.", t, MAX_RETRIES - retryCounter);
- repeaterForChangeRole(future, input, (retryCounter + 1));
+ if (!t.getMessage().contains(ROLE_REQUEST_UNSUPPORTED)) {
+ LOG.warn("Exception in setRole(), will retry: {} times.", t, MAX_RETRIES - retryCounter);
+ repeaterForChangeRole(future, input, (retryCounter + 1));
+ } else {
+ LOG.warn("Exception in setRole() - role request unsupported.", t);
+ future.set(RpcResultBuilder.<SetRoleOutput>failed()
+ .withError(RpcError.ErrorType.APPLICATION, t.getMessage()).build());
+ }
}
});
}
package org.opendaylight.openflowplugin.impl.services.sal;
import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
import org.opendaylight.openflowplugin.api.openflow.device.RequestContextStack;
import org.opendaylight.openflowplugin.api.openflow.device.Xid;
import org.opendaylight.openflowplugin.api.openflow.statistics.ofpspecific.MessageSpy;
-import org.opendaylight.openflowplugin.impl.services.sal.SalRoleServiceImpl;
import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Uri;
import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeId;
import org.opendaylight.yang.gen.v1.urn.opendaylight.inventory.rev130819.NodeRef;
import org.opendaylight.yang.gen.v1.urn.opendaylight.role.service.rev150727.SetRoleInputBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.role.service.rev150727.SetRoleOutput;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
+import org.opendaylight.yangtools.yang.common.RpcError.ErrorType;
import org.opendaylight.yangtools.yang.common.RpcResult;
import org.opendaylight.yangtools.yang.common.RpcResultBuilder;
private static long testXid = 100L;
+ private static final String ROLEREQUESTFAILED =
+ org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.ErrorType.ROLEREQUESTFAILED.name();
+
+ private static final String ROLES_UNSUPPORTED = "Device reported error type "+ ROLEREQUESTFAILED +" code UNSUP";
+
private NodeRef nodeRef;
@Before
}
+ @Test
+ public void testSetRoleUnsupported() throws Exception {
+ ListenableFuture<RpcResult<RoleRequestOutput>> futureOutput =
+ RpcResultBuilder.<RoleRequestOutput>failed()
+ .withError(ErrorType.APPLICATION, ROLES_UNSUPPORTED)
+ .buildFuture();
+
+ Mockito.when(mockRequestContext.getFuture()).thenReturn(futureOutput);
+
+ SalRoleService salRoleService = new SalRoleServiceImpl(mockRequestContextStack, mockDeviceContext);
+
+ SetRoleInput setRoleInput = new SetRoleInputBuilder()
+ .setControllerRole(OfpRole.BECOMESLAVE)
+ .setNode(nodeRef)
+ .build();
+
+ Future<RpcResult<SetRoleOutput>> future = salRoleService.setRole(setRoleInput);
+
+ RpcResult<SetRoleOutput> roleOutputRpcResult = future.get(5, TimeUnit.SECONDS);
+ assertNotNull("RpcResult from future cannot be null.", roleOutputRpcResult);
+ assertFalse("RpcResult from future is successful.", roleOutputRpcResult.isSuccessful());
+ assertEquals(ROLES_UNSUPPORTED, roleOutputRpcResult
+ .getErrors().iterator().next().getMessage());
+ }
+
@Test
public void testDuplicateRoles() throws Exception {
// set role to slave