I found an issue with the JndiLoginInitialContextFactory not creating a SecurityContext and hence not being propagated correctly by the org.jboss.ejb3.security.client.SecurityClientInterceptor. Looking at the SecurityClientInterceptor it seems the logic for creating a SecurityContext if one is not found should be updated to include the principal and credential:
 // Get Principal and credentials
 Principal principal = SecurityActions.getPrincipal();
 if (principal != null) invocation.getMetaData().addMetaData("security", "principal", principal);
 Object credential = SecurityActions.getCredential();
 if (credential != null) invocation.getMetaData().addMetaData("security", "credential", credential);
 //Get the security context
 SecurityContext sc = SecurityActions.getSecurityContext();
 if(sc == null)
 {
 sc = SecurityActions.createSecurityContext();
 SecurityActions.setSecurityContext(sc);
 }
Scott, we will fix it asap.