Merge pull request #6169 from FDPro/bael-2424
dupirefr/dupire.francois+pro@gmail.com [BAEL-2424] Removed order checking + filtering public and protected fields
This commit is contained in:
commit
69e29b364d
|
@ -2,6 +2,6 @@ package com.baeldung.reflection;
|
|||
|
||||
public class MonthEmployee extends Employee {
|
||||
|
||||
private double reward;
|
||||
protected double reward;
|
||||
|
||||
}
|
||||
|
|
|
@ -2,7 +2,7 @@ package com.baeldung.reflection;
|
|||
|
||||
public class Person {
|
||||
|
||||
public String lastName;
|
||||
protected String lastName;
|
||||
private String firstName;
|
||||
|
||||
}
|
||||
|
|
|
@ -3,10 +3,13 @@ package com.baeldung.reflection;
|
|||
import org.junit.Test;
|
||||
|
||||
import java.lang.reflect.Field;
|
||||
import java.lang.reflect.Modifier;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
import java.util.stream.Collectors;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
|
@ -26,30 +29,14 @@ public class PersonAndEmployeeReflectionUnitTest {
|
|||
// Then
|
||||
assertEquals(2, allFields.length);
|
||||
|
||||
Field lastNameField = allFields[0];
|
||||
assertEquals(LAST_NAME_FIELD, lastNameField.getName());
|
||||
assertEquals(String.class, lastNameField.getType());
|
||||
|
||||
Field firstNameField = allFields[1];
|
||||
assertEquals(FIRST_NAME_FIELD, firstNameField.getName());
|
||||
assertEquals(String.class, firstNameField.getType());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenEmployeeClass_whenSuperClassGetDeclaredFields_thenOneField() {
|
||||
// When
|
||||
Field[] allFields = Employee.class.getSuperclass().getDeclaredFields();
|
||||
|
||||
// Then
|
||||
assertEquals(2, allFields.length);
|
||||
|
||||
Field lastNameField = allFields[0];
|
||||
assertEquals(LAST_NAME_FIELD, lastNameField.getName());
|
||||
assertEquals(String.class, lastNameField.getType());
|
||||
|
||||
Field firstNameField = allFields[1];
|
||||
assertEquals(FIRST_NAME_FIELD, firstNameField.getName());
|
||||
assertEquals(String.class, firstNameField.getType());
|
||||
assertTrue(Arrays.stream(allFields).anyMatch(field ->
|
||||
field.getName().equals(LAST_NAME_FIELD)
|
||||
&& field.getType().equals(String.class))
|
||||
);
|
||||
assertTrue(Arrays.stream(allFields).anyMatch(field ->
|
||||
field.getName().equals(FIRST_NAME_FIELD)
|
||||
&& field.getType().equals(String.class))
|
||||
);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -60,9 +47,28 @@ public class PersonAndEmployeeReflectionUnitTest {
|
|||
// Then
|
||||
assertEquals(1, allFields.length);
|
||||
|
||||
Field employeeIdField = allFields[0];
|
||||
assertEquals(EMPLOYEE_ID_FIELD, employeeIdField.getName());
|
||||
assertEquals(int.class, employeeIdField.getType());
|
||||
assertTrue(Arrays.stream(allFields).anyMatch(field ->
|
||||
field.getName().equals(EMPLOYEE_ID_FIELD)
|
||||
&& field.getType().equals(int.class))
|
||||
);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenEmployeeClass_whenSuperClassGetDeclaredFields_thenOneField() {
|
||||
// When
|
||||
Field[] allFields = Employee.class.getSuperclass().getDeclaredFields();
|
||||
|
||||
// Then
|
||||
assertEquals(2, allFields.length);
|
||||
|
||||
assertTrue(Arrays.stream(allFields).anyMatch(field ->
|
||||
field.getName().equals(LAST_NAME_FIELD)
|
||||
&& field.getType().equals(String.class))
|
||||
);
|
||||
assertTrue(Arrays.stream(allFields).anyMatch(field ->
|
||||
field.getName().equals(FIRST_NAME_FIELD)
|
||||
&& field.getType().equals(String.class))
|
||||
);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
@ -76,42 +82,56 @@ public class PersonAndEmployeeReflectionUnitTest {
|
|||
// Then
|
||||
assertEquals(3, allFields.length);
|
||||
|
||||
Field lastNameField = allFields[0];
|
||||
assertEquals(LAST_NAME_FIELD, lastNameField.getName());
|
||||
assertEquals(String.class, lastNameField.getType());
|
||||
|
||||
Field firstNameField = allFields[1];
|
||||
assertEquals(FIRST_NAME_FIELD, firstNameField.getName());
|
||||
assertEquals(String.class, firstNameField.getType());
|
||||
|
||||
Field employeeIdField = allFields[2];
|
||||
assertEquals(EMPLOYEE_ID_FIELD, employeeIdField.getName());
|
||||
assertEquals(int.class, employeeIdField.getType());
|
||||
assertTrue(Arrays.stream(allFields).anyMatch(field ->
|
||||
field.getName().equals(LAST_NAME_FIELD)
|
||||
&& field.getType().equals(String.class))
|
||||
);
|
||||
assertTrue(Arrays.stream(allFields).anyMatch(field ->
|
||||
field.getName().equals(FIRST_NAME_FIELD)
|
||||
&& field.getType().equals(String.class))
|
||||
);
|
||||
assertTrue(Arrays.stream(allFields).anyMatch(field ->
|
||||
field.getName().equals(EMPLOYEE_ID_FIELD)
|
||||
&& field.getType().equals(int.class))
|
||||
);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenMonthEmployeeClass_whenGetAllFields_thenFourFields() {
|
||||
public void givenEmployeeClass_whenGetDeclaredFieldsOnEmployeeSuperclassWithModifiersFilter_thenOneFields() {
|
||||
// When
|
||||
List<Field> personFields = Arrays.stream(Employee.class.getSuperclass().getDeclaredFields())
|
||||
.filter(f -> Modifier.isPublic(f.getModifiers()) || Modifier.isProtected(f.getModifiers()))
|
||||
.collect(Collectors.toList());
|
||||
|
||||
// Then
|
||||
assertEquals(1, personFields.size());
|
||||
|
||||
assertTrue(personFields.stream().anyMatch(field ->
|
||||
field.getName().equals(LAST_NAME_FIELD)
|
||||
&& field.getType().equals(String.class))
|
||||
);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void givenMonthEmployeeClass_whenGetAllFields_thenThreeFields() {
|
||||
// When
|
||||
List<Field> allFields = getAllFields(MonthEmployee.class);
|
||||
|
||||
// Then
|
||||
assertEquals(4, allFields.size());
|
||||
assertEquals(3, allFields.size());
|
||||
|
||||
Field lastNameField = allFields.get(0);
|
||||
assertEquals(LAST_NAME_FIELD, lastNameField.getName());
|
||||
assertEquals(String.class, lastNameField.getType());
|
||||
|
||||
Field firstNameField = allFields.get(1);
|
||||
assertEquals(FIRST_NAME_FIELD, firstNameField.getName());
|
||||
assertEquals(String.class, firstNameField.getType());
|
||||
|
||||
Field employeeIdField = allFields.get(2);
|
||||
assertEquals(EMPLOYEE_ID_FIELD, employeeIdField.getName());
|
||||
assertEquals(int.class, employeeIdField.getType());
|
||||
|
||||
Field monthEmployeeRewardField = allFields.get(3);
|
||||
assertEquals(MONTH_EMPLOYEE_REWARD_FIELD, monthEmployeeRewardField.getName());
|
||||
assertEquals(double.class, monthEmployeeRewardField.getType());
|
||||
assertTrue(allFields.stream().anyMatch(field ->
|
||||
field.getName().equals(LAST_NAME_FIELD)
|
||||
&& field.getType().equals(String.class))
|
||||
);
|
||||
assertTrue(allFields.stream().anyMatch(field ->
|
||||
field.getName().equals(EMPLOYEE_ID_FIELD)
|
||||
&& field.getType().equals(int.class))
|
||||
);
|
||||
assertTrue(allFields.stream().anyMatch(field ->
|
||||
field.getName().equals(MONTH_EMPLOYEE_REWARD_FIELD)
|
||||
&& field.getType().equals(double.class))
|
||||
);
|
||||
}
|
||||
|
||||
public List<Field> getAllFields(Class clazz) {
|
||||
|
@ -119,9 +139,11 @@ public class PersonAndEmployeeReflectionUnitTest {
|
|||
return Collections.emptyList();
|
||||
}
|
||||
|
||||
List<Field> result = new ArrayList<>();
|
||||
result.addAll(getAllFields(clazz.getSuperclass()));
|
||||
result.addAll(Arrays.asList(clazz.getDeclaredFields()));
|
||||
List<Field> result = new ArrayList<>(getAllFields(clazz.getSuperclass()));
|
||||
List<Field> filteredFields = Arrays.stream(clazz.getDeclaredFields())
|
||||
.filter(f -> Modifier.isPublic(f.getModifiers()) || Modifier.isProtected(f.getModifiers()))
|
||||
.collect(Collectors.toList());
|
||||
result.addAll(filteredFields);
|
||||
return result;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue