blob: 39a238d62c2f2dcc2f74d713e272f96764652dcc [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more contributor license
* agreements. See the NOTICE file distributed with this work for additional information regarding
* copyright ownership. The ASF licenses this file to You under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance with the License. You may obtain a
* copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/
package org.apache.geode.distributed.internal.membership.adapter.auth;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import java.security.Principal;
import java.util.Properties;
import org.apache.shiro.subject.Subject;
import org.junit.Before;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.apache.geode.LogWriter;
import org.apache.geode.distributed.DistributedMember;
import org.apache.geode.distributed.internal.DistributionConfig;
import org.apache.geode.distributed.internal.membership.gms.ServiceConfig;
import org.apache.geode.distributed.internal.membership.gms.Services;
import org.apache.geode.internal.security.SecurityService;
import org.apache.geode.security.AuthInitialize;
import org.apache.geode.security.AuthenticationFailedException;
import org.apache.geode.security.Authenticator;
public abstract class AbstractGMSAuthenticatorTestCase {
@Mock
protected SecurityService securityService;
@Mock
protected Properties props;
@Mock
protected Properties securityProps;
@Mock
protected Services services;
@Mock
protected DistributedMember member;
@Mock
protected Subject subject;
@Mock
private ServiceConfig serviceConfig;
@Mock
private DistributionConfig distributionConfig;
protected GMSAuthenticator authenticator;
@Before
public void setUp() throws Exception {
clearStatics();
MockitoAnnotations.initMocks(this);
this.props = new Properties();
this.securityProps = new Properties();
this.authenticator = new GMSAuthenticator(securityProps, securityService, mock(LogWriter.class),
mock(LogWriter.class));
when(this.securityService.isIntegratedSecurity()).thenReturn(isIntegratedSecurity());
when(this.securityService.isPeerSecurityRequired()).thenReturn(true);
when(this.securityService.login(this.securityProps)).thenReturn(this.subject);
when(this.distributionConfig.getSecurityProps()).thenReturn(this.securityProps);
when(this.serviceConfig.getDistributionConfig()).thenReturn(this.distributionConfig);
when(this.services.getConfig()).thenReturn(this.serviceConfig);
}
protected abstract boolean isIntegratedSecurity();
private static void clearStatics() {
SpyAuthInit.clear();
SpyAuthenticator.clear();
}
protected static class AuthInitCreateReturnsNull implements AuthInitialize {
public static AuthInitialize create() {
return null;
}
@Override
public void init(LogWriter systemLogger, LogWriter securityLogger)
throws AuthenticationFailedException {}
@Override
public Properties getCredentials(Properties props, DistributedMember server, boolean isPeer)
throws AuthenticationFailedException {
throw new AuthenticationFailedException("expected get credential error");
}
@Override
public void close() {}
}
protected static class SpyAuthInit implements AuthInitialize {
private static SpyAuthInit instance = null;
private static int createCount = 0;
boolean closed = false;
static void clear() {
instance = null;
createCount = 0;
}
public static void setAuthInitialize(SpyAuthInit auth) {
instance = auth;
}
public static AuthInitialize create() {
createCount++;
return instance;
}
@Override
public Properties getCredentials(Properties props, DistributedMember server, boolean isPeer)
throws AuthenticationFailedException {
return props;
}
@Override
public void close() {
this.closed = true;
}
public boolean isClosed() {
return this.closed;
}
public static int getCreateCount() {
return createCount;
}
@Override
public void init(LogWriter systemLogger, LogWriter securityLogger)
throws AuthenticationFailedException {}
}
protected static class AuthInitGetCredentialsAndInitThrow implements AuthInitialize {
public static AuthInitialize create() {
return new AuthInitGetCredentialsAndInitThrow();
}
@Override
public void init(LogWriter systemLogger, LogWriter securityLogger)
throws AuthenticationFailedException {
throw new AuthenticationFailedException("expected init error");
}
@Override
public Properties getCredentials(Properties props, DistributedMember server, boolean isPeer)
throws AuthenticationFailedException {
throw new AuthenticationFailedException("expected get credential error");
}
@Override
public void close() {}
}
protected static class AuthInitGetCredentialsThrows implements AuthInitialize {
public static AuthInitialize create() {
return new AuthInitGetCredentialsThrows();
}
@Override
public void init(LogWriter systemLogger, LogWriter securityLogger)
throws AuthenticationFailedException {}
@Override
public Properties getCredentials(Properties props, DistributedMember server, boolean isPeer)
throws AuthenticationFailedException {
throw new AuthenticationFailedException("expected get credential error");
}
@Override
public void close() {}
}
protected static class AuthenticatorReturnsNulls implements Authenticator {
public static Authenticator create() {
return null;
}
@Override
public void init(Properties securityProps, LogWriter systemLogger, LogWriter securityLogger)
throws AuthenticationFailedException {}
@Override
public Principal authenticate(Properties props, DistributedMember member)
throws AuthenticationFailedException {
return null;
}
@Override
public void close() {}
}
protected static class AuthenticatorInitThrows implements Authenticator {
public static Authenticator create() {
return new AuthenticatorInitThrows();
}
@Override
public void init(Properties securityProps, LogWriter systemLogger, LogWriter securityLogger)
throws AuthenticationFailedException {
throw new AuthenticationFailedException("expected init error");
}
@Override
public Principal authenticate(Properties props, DistributedMember member)
throws AuthenticationFailedException {
return null;
}
@Override
public void close() {}
}
protected static class AuthenticatorAuthenticateThrows implements Authenticator {
public static Authenticator create() {
return new AuthenticatorAuthenticateThrows();
}
@Override
public Principal authenticate(Properties props, DistributedMember member)
throws AuthenticationFailedException {
throw new AuthenticationFailedException("expected authenticate error");
}
@Override
public void init(Properties securityProps, LogWriter systemLogger, LogWriter securityLogger)
throws AuthenticationFailedException {}
@Override
public void close() {}
}
protected static class SpyAuthenticator implements Authenticator {
private static Authenticator instance = null;
private static int createCount = 0;
private boolean closed = false;
static void clear() {
instance = null;
createCount = 0;
}
public static void setAuthenticator(Authenticator auth) {
instance = auth;
}
public static Authenticator create() {
createCount++;
return instance;
}
@Override
public Principal authenticate(Properties props, DistributedMember member)
throws AuthenticationFailedException {
return null;
}
@Override
public void close() {
this.closed = true;
}
public boolean isClosed() {
return this.closed;
}
public static int getCreateCount() {
return createCount;
}
@Override
public void init(Properties securityProps, LogWriter systemLogger, LogWriter securityLogger)
throws AuthenticationFailedException {}
}
}