Skip to content

Commit fd1c286

Browse files
[JAVA-5730] convert list of objects to list of strings (#13166)
* [JAVA-5730] convert list of objects to list of strings * [JAVA-5730] added new unit tests with null and non-null lists. modified pom.xml with java version to 16 * [JAVA-5730] simplified User class and formatted the codebase * [JAVA-5730] added module in jdk-9 and above profile * [JAVA-5730] removed arraylist module from other profiles of core-java pom * [JAVA-5730] java util opened for reflection surefire plugin Co-authored-by: Bhaskar <bhaskar.dastidar@freshworks.com>
1 parent dcb6c85 commit fd1c286

6 files changed

Lines changed: 157 additions & 1 deletion

File tree

core-java-modules/core-java-collections-array-list/pom.xml

Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,33 @@
55
<modelVersion>4.0.0</modelVersion>
66
<artifactId>core-java-collections-array-list</artifactId>
77
<version>0.1.0-SNAPSHOT</version>
8+
<build>
9+
<plugins>
10+
<plugin>
11+
<groupId>org.apache.maven.plugins</groupId>
12+
<artifactId>maven-compiler-plugin</artifactId>
13+
<configuration>
14+
<source>${maven-compiler-plugin.source}</source>
15+
<target>${maven-compiler-plugin.target}</target>
16+
</configuration>
17+
</plugin>
18+
<plugin>
19+
<groupId>org.apache.maven.plugins</groupId>
20+
<artifactId>maven-surefire-plugin</artifactId>
21+
<version>${surefire.plugin.version}</version>
22+
<configuration>
23+
<argLine>
24+
--add-opens java.base/java.util=ALL-UNNAMED
25+
</argLine>
26+
</configuration>
27+
</plugin>
28+
</plugins>
29+
</build>
30+
<properties>
31+
<maven-compiler-plugin.source>16</maven-compiler-plugin.source>
32+
<maven-compiler-plugin.target>16</maven-compiler-plugin.target>
33+
<surefire.plugin.version>3.0.0-M3</surefire.plugin.version>
34+
</properties>
835
<name>core-java-collections-array-list</name>
936
<packaging>jar</packaging>
1037

@@ -20,6 +47,12 @@
2047
<artifactId>commons-collections4</artifactId>
2148
<version>${commons-collections4.version}</version>
2249
</dependency>
50+
<dependency>
51+
<groupId>com.google.guava</groupId>
52+
<artifactId>guava</artifactId>
53+
<version>31.1-jre</version>
54+
<scope>test</scope>
55+
</dependency>
2356
</dependencies>
2457

2558
</project>
Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
package com.baeldung.listofobjectstolistofstring;
2+
3+
public class Node {
4+
5+
private final int x;
6+
private final int y;
7+
8+
public Node(int x, int y) {
9+
this.x = x;
10+
this.y = y;
11+
}
12+
13+
@Override
14+
public String toString() {
15+
return "Node (" + "x=" + x + ", y=" + y + ')';
16+
}
17+
}
Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
package com.baeldung.listofobjectstolistofstring;
2+
3+
public class User {
4+
private final String fullName;
5+
6+
public User(String fullName) {
7+
this.fullName = fullName;
8+
}
9+
10+
@Override
11+
public String toString() {
12+
return "User (" + "full name='" + fullName + ')';
13+
}
14+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,92 @@
1+
package com.baeldung.listofobjectstolistofstring;
2+
3+
import com.google.common.collect.Lists;
4+
5+
import org.junit.Assert;
6+
import org.junit.Test;
7+
8+
import java.util.ArrayList;
9+
import java.util.List;
10+
import java.util.Objects;
11+
import java.util.stream.Collectors;
12+
13+
public class ConvertObjectListToStringListUnitTest {
14+
15+
@Test
16+
public void givenObjectList_whenForEachUsedToConvert_thenReturnSuccess() {
17+
List<String> outputList = new ArrayList<>(objectListWithNull().size());
18+
for (Object obj : objectListWithNull()) {
19+
outputList.add(Objects.toString(obj, null));
20+
}
21+
Assert.assertEquals(expectedStringListWithNull(), outputList);
22+
}
23+
24+
@Test
25+
public void givenObjectList_whenUsingStreamsToConvert_thenReturnSuccess() {
26+
List<String> outputList;
27+
outputList = objectListWithNull().stream()
28+
.map((obj) -> Objects.toString(obj, null))
29+
.collect(Collectors.toList());
30+
Assert.assertEquals(expectedStringListWithNull(), outputList);
31+
32+
}
33+
34+
@Test
35+
public void givenObjectList_whenUsingStreamsUnmodifiableListToConvert_thenReturnSuccess() {
36+
List<String> outputList;
37+
outputList = objectListWithNull().stream()
38+
.filter(Objects::nonNull)
39+
.map((obj) -> Objects.toString(obj, null))
40+
.collect(Collectors.toUnmodifiableList());
41+
Assert.assertEquals(expectedStringListWithoutNull(), outputList);
42+
43+
}
44+
45+
@Test
46+
public void givenObjectList_whenUsingGuavaTransform_thenReturnSuccess() {
47+
List<String> outputList;
48+
outputList = Lists.transform(objectListWithNull(), obj -> Objects.toString(obj, null));
49+
Assert.assertEquals(expectedStringListWithNull(), outputList);
50+
}
51+
52+
@Test
53+
public void givenObjectListWithNoNull_whenUsingToList_thenReturnSuccess() {
54+
List<String> outputList;
55+
outputList = objectListWithoutNull().stream()
56+
.map((obj) -> Objects.toString(obj, null))
57+
.toList();
58+
Assert.assertEquals(expectedStringListWithoutNull(), outputList);
59+
}
60+
61+
private List<String> expectedStringListWithNull() {
62+
List<String> listOfStrings = new ArrayList<>();
63+
listOfStrings.add("1");
64+
listOfStrings.add("true");
65+
listOfStrings.add("hello");
66+
listOfStrings.add(Double.toString(273773.98));
67+
listOfStrings.add(null);
68+
listOfStrings.add(new Node(2, 4).toString());
69+
listOfStrings.add(new User("John Doe").toString());
70+
return listOfStrings;
71+
}
72+
73+
private List<Object> objectListWithNull() {
74+
List<Object> listOfStrings = new ArrayList<>();
75+
listOfStrings.add(1);
76+
listOfStrings.add(true);
77+
listOfStrings.add("hello");
78+
listOfStrings.add(Double.valueOf(273773.98));
79+
listOfStrings.add(null);
80+
listOfStrings.add(new Node(2, 4));
81+
listOfStrings.add(new User("John Doe"));
82+
return listOfStrings;
83+
}
84+
85+
private List<String> expectedStringListWithoutNull() {
86+
return List.of("1", "true", "hello", Double.toString(273773.98), new Node(2, 4).toString(), new User("John Doe").toString());
87+
}
88+
89+
private List<Object> objectListWithoutNull() {
90+
return List.of(1, true, "hello", Double.valueOf(273773.98), new Node(2, 4), new User("John Doe"));
91+
}
92+
}

core-java-modules/pom.xml

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,6 @@
3131
<module>core-java-collections-2</module>
3232
<module>core-java-collections-3</module>
3333
<module>core-java-collections-4</module>
34-
<module>core-java-collections-array-list</module>
3534
<module>core-java-collections-conversions</module>
3635
<module>core-java-collections-conversions-2</module>
3736
<module>core-java-collections-set-2</module>

pom.xml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1133,6 +1133,7 @@
11331133
<!-- <module>core-java-modules/core-java-19</module> --> <!-- uses preview features, to be decided how to handle -->
11341134
<module>core-java-modules/core-java-collections-set</module>
11351135
<module>core-java-modules/core-java-collections-list-4</module>
1136+
<module>core-java-modules/core-java-collections-array-list</module>
11361137
<module>core-java-modules/core-java-collections-maps-4</module>
11371138
<module>core-java-modules/core-java-collections-maps-5</module>
11381139
<module>core-java-modules/core-java-concurrency-simple</module>

0 commit comments

Comments
 (0)