Added null checks and tests to constructors

RequestKey, JaasGrantedAuthority, and SwitchUserGrantedAuthority
assume certain final members are non-null.

Issue: gh-6892
This commit is contained in:
Clement Ng 2019-05-28 19:35:06 -07:00 committed by Josh Cummings
parent 9fe8949883
commit e66369f6c6
6 changed files with 123 additions and 4 deletions

View File

@ -18,6 +18,7 @@ package org.springframework.security.authentication.jaas;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.SpringSecurityCoreVersion;
import org.springframework.util.Assert;
import java.security.Principal;
@ -37,6 +38,8 @@ public final class JaasGrantedAuthority implements GrantedAuthority {
private final Principal principal;
public JaasGrantedAuthority(String role, Principal principal) {
Assert.notNull(role, "role cannot be null");
Assert.notNull(principal, "principal cannot be null");
this.role = role;
this.principal = principal;
}

View File

@ -0,0 +1,50 @@
/*
* Copyright 2002-2019 the original author or authors.
*
* Licensed 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
*
* https://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.springframework.security.authentication.jaas;
import org.junit.Test;
import static org.assertj.core.api.Assertions.assertThatThrownBy;
import org.springframework.security.authentication.jaas.JaasGrantedAuthority;
/**
*
* @author Clement Ng
*
*/
public class JaasGrantedAuthorityTests {
/**
* @throws Exception
*/
@Test
public void authorityWithNullRoleFailsAssertion() throws Exception {
assertThatThrownBy(() -> new JaasGrantedAuthority(null, null))
.isInstanceOf(IllegalArgumentException.class)
.hasMessageContaining("role cannot be null");
}
/**
* @throws Exception
*/
@Test
public void authorityWithNullPrincipleFailsAssertion() throws Exception {
assertThatThrownBy(() -> new JaasGrantedAuthority("role", null))
.isInstanceOf(IllegalArgumentException.class)
.hasMessageContaining("principal cannot be null");
}
}

View File

@ -1,5 +1,5 @@
/*
* Copyright 2002-2016 the original author or authors.
* Copyright 2002-2019 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@ -15,6 +15,8 @@
*/
package org.springframework.security.web.access.intercept;
import org.springframework.util.Assert;
/**
* @author Luke Taylor
* @since 2.0
@ -28,6 +30,7 @@ public class RequestKey {
}
public RequestKey(String url, String method) {
Assert.notNull(url, "url cannot be null");
this.url = url;
this.method = method;
}

View File

@ -19,6 +19,7 @@ package org.springframework.security.web.authentication.switchuser;
import org.springframework.security.core.Authentication;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.SpringSecurityCoreVersion;
import org.springframework.util.Assert;
/**
* Custom {@code GrantedAuthority} used by
@ -44,6 +45,8 @@ public final class SwitchUserGrantedAuthority implements GrantedAuthority {
// ===================================================================================================
public SwitchUserGrantedAuthority(String role, Authentication source) {
Assert.notNull(role, "role cannot be null");
Assert.notNull(source, "source cannot be null");
this.role = role;
this.source = source;
}

View File

@ -1,5 +1,5 @@
/*
* Copyright 2002-2016 the original author or authors.
* Copyright 2002-2019 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@ -15,9 +15,10 @@
*/
package org.springframework.security.web.access.intercept;
import static org.assertj.core.api.Assertions.*;
import org.junit.Test;
import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.assertThatThrownBy;
import org.springframework.security.web.access.intercept.RequestKey;
/**
@ -63,4 +64,14 @@ public class RequestKeyTests {
assertThat(key1.equals(key2)).isFalse();
assertThat(key2.equals(key1)).isFalse();
}
/**
* @throws Exception
*/
@Test
public void keysWithNullUrlFailsAssertion() throws Exception {
assertThatThrownBy(() -> new RequestKey(null, null))
.isInstanceOf(IllegalArgumentException.class)
.hasMessage("url cannot be null");
}
}

View File

@ -0,0 +1,49 @@
/*
* Copyright 2002-2019 the original author or authors.
*
* Licensed 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
*
* https://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.springframework.security.web.authentication.switchuser;
import org.junit.Test;
import static org.assertj.core.api.Assertions.assertThatThrownBy;
import org.springframework.security.web.authentication.switchuser.SwitchUserGrantedAuthority;
/**
*
* @author Clement Ng
*
*/
public class SwitchUserGrantedAuthorityTests {
/**
* @throws Exception
*/
@Test
public void authorityWithNullRoleFailsAssertion() throws Exception {
assertThatThrownBy(() -> new SwitchUserGrantedAuthority(null, null))
.isInstanceOf(IllegalArgumentException.class)
.hasMessage("role cannot be null");
}
/**
* @throws Exception
*/
@Test
public void authorityWithNullSourceFailsAssertion() throws Exception {
assertThatThrownBy(() -> new SwitchUserGrantedAuthority("role", null))
.isInstanceOf(IllegalArgumentException.class)
.hasMessage("source cannot be null");
}
}