|
@@ -21,11 +21,12 @@ import java.util.Arrays;
|
|
import java.util.List;
|
|
import java.util.List;
|
|
import java.util.Set;
|
|
import java.util.Set;
|
|
|
|
|
|
|
|
+import org.junit.Assume;
|
|
import org.junit.Before;
|
|
import org.junit.Before;
|
|
import org.junit.Test;
|
|
import org.junit.Test;
|
|
-import org.springframework.core.DefaultParameterNameDiscoverer;
|
|
|
|
import org.springframework.core.LocalVariableTableParameterNameDiscoverer;
|
|
import org.springframework.core.LocalVariableTableParameterNameDiscoverer;
|
|
import org.springframework.core.ParameterNameDiscoverer;
|
|
import org.springframework.core.ParameterNameDiscoverer;
|
|
|
|
+import org.springframework.core.SpringVersion;
|
|
import org.springframework.security.access.method.P;
|
|
import org.springframework.security.access.method.P;
|
|
import org.springframework.test.util.ReflectionTestUtils;
|
|
import org.springframework.test.util.ReflectionTestUtils;
|
|
|
|
|
|
@@ -45,6 +46,8 @@ public class DefaultSecurityParameterNameDiscovererTests {
|
|
|
|
|
|
@Test
|
|
@Test
|
|
public void constructorDefault() {
|
|
public void constructorDefault() {
|
|
|
|
+ Assume.assumeTrue(SpringVersion.getVersion().startsWith("3."));
|
|
|
|
+
|
|
List<ParameterNameDiscoverer> discoverers = (List<ParameterNameDiscoverer>) ReflectionTestUtils
|
|
List<ParameterNameDiscoverer> discoverers = (List<ParameterNameDiscoverer>) ReflectionTestUtils
|
|
.getField(discoverer, "parameterNameDiscoverers");
|
|
.getField(discoverer, "parameterNameDiscoverers");
|
|
|
|
|
|
@@ -57,11 +60,13 @@ public class DefaultSecurityParameterNameDiscovererTests {
|
|
assertThat(annotationsToUse).containsOnly(P.class.getName());
|
|
assertThat(annotationsToUse).containsOnly(P.class.getName());
|
|
|
|
|
|
assertThat(discoverers.get(1)).isInstanceOf(
|
|
assertThat(discoverers.get(1)).isInstanceOf(
|
|
- DefaultParameterNameDiscoverer.class);
|
|
|
|
|
|
+ LocalVariableTableParameterNameDiscoverer.class);
|
|
}
|
|
}
|
|
|
|
|
|
@Test
|
|
@Test
|
|
public void constructorDiscoverers() {
|
|
public void constructorDiscoverers() {
|
|
|
|
+ Assume.assumeTrue(SpringVersion.getVersion().startsWith("3."));
|
|
|
|
+
|
|
discoverer = new DefaultSecurityParameterNameDiscoverer(Arrays.asList(new LocalVariableTableParameterNameDiscoverer()));
|
|
discoverer = new DefaultSecurityParameterNameDiscoverer(Arrays.asList(new LocalVariableTableParameterNameDiscoverer()));
|
|
|
|
|
|
List<ParameterNameDiscoverer> discoverers = (List<ParameterNameDiscoverer>) ReflectionTestUtils
|
|
List<ParameterNameDiscoverer> discoverers = (List<ParameterNameDiscoverer>) ReflectionTestUtils
|
|
@@ -78,6 +83,46 @@ public class DefaultSecurityParameterNameDiscovererTests {
|
|
assertThat(annotationsToUse).containsOnly(P.class.getName());
|
|
assertThat(annotationsToUse).containsOnly(P.class.getName());
|
|
|
|
|
|
assertThat(discoverers.get(2)).isInstanceOf(
|
|
assertThat(discoverers.get(2)).isInstanceOf(
|
|
- DefaultParameterNameDiscoverer.class);
|
|
|
|
|
|
+ LocalVariableTableParameterNameDiscoverer.class);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Test
|
|
|
|
+ public void constructorDefaultSpring4() {
|
|
|
|
+ Assume.assumeTrue(SpringVersion.getVersion().startsWith("4."));
|
|
|
|
+
|
|
|
|
+ List<ParameterNameDiscoverer> discoverers = (List<ParameterNameDiscoverer>) ReflectionTestUtils
|
|
|
|
+ .getField(discoverer, "parameterNameDiscoverers");
|
|
|
|
+
|
|
|
|
+ assertThat(discoverers.size()).isEqualTo(2);
|
|
|
|
+
|
|
|
|
+ ParameterNameDiscoverer annotationDisc = discoverers.get(0);
|
|
|
|
+ assertThat(annotationDisc).isInstanceOf(
|
|
|
|
+ AnnotationParameterNameDiscoverer.class);
|
|
|
|
+ Set<String> annotationsToUse = (Set<String>)ReflectionTestUtils.getField(annotationDisc, "annotationClassesToUse");
|
|
|
|
+ assertThat(annotationsToUse).containsOnly(P.class.getName());
|
|
|
|
+
|
|
|
|
+ assertThat(discoverers.get(1).getClass().getName()).isEqualTo("org.springframework.core.DefaultParameterNameDiscoverer");
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Test
|
|
|
|
+ public void constructorDiscoverersSpring4() {
|
|
|
|
+ Assume.assumeTrue(SpringVersion.getVersion().startsWith("4."));
|
|
|
|
+
|
|
|
|
+ discoverer = new DefaultSecurityParameterNameDiscoverer(Arrays.asList(new LocalVariableTableParameterNameDiscoverer()));
|
|
|
|
+
|
|
|
|
+ List<ParameterNameDiscoverer> discoverers = (List<ParameterNameDiscoverer>) ReflectionTestUtils
|
|
|
|
+ .getField(discoverer, "parameterNameDiscoverers");
|
|
|
|
+
|
|
|
|
+ assertThat(discoverers.size()).isEqualTo(3);
|
|
|
|
+ assertThat(discoverers.get(0)).isInstanceOf(
|
|
|
|
+ LocalVariableTableParameterNameDiscoverer.class);
|
|
|
|
+
|
|
|
|
+ ParameterNameDiscoverer annotationDisc = discoverers.get(1);
|
|
|
|
+ assertThat(annotationDisc).isInstanceOf(
|
|
|
|
+ AnnotationParameterNameDiscoverer.class);
|
|
|
|
+ Set<String> annotationsToUse = (Set<String>)ReflectionTestUtils.getField(annotationDisc, "annotationClassesToUse");
|
|
|
|
+ assertThat(annotationsToUse).containsOnly(P.class.getName());
|
|
|
|
+
|
|
|
|
+ assertThat(discoverers.get(1).getClass().getName()).isEqualTo("org.springframework.core.DefaultParameterNameDiscoverer");
|
|
}
|
|
}
|
|
}
|
|
}
|