Merge pull request #12490 from hkhan/JAVA-13290-sync-article-code
[JAVA-13290] Update record name
This commit is contained in:
commit
3db189f71a
|
@ -4,15 +4,15 @@ import java.util.IntSummaryStatistics;
|
||||||
|
|
||||||
|
|
||||||
public class BlogPost {
|
public class BlogPost {
|
||||||
|
|
||||||
private String title;
|
private String title;
|
||||||
private String author;
|
private String author;
|
||||||
private BlogPostType type;
|
private BlogPostType type;
|
||||||
private int likes;
|
private int likes;
|
||||||
record AuthPostTypesLikes(String author, BlogPostType type, int likes) {};
|
record AuthPostTypesLikes(String author, BlogPostType type, int likes) {};
|
||||||
record PostcountTitlesLikesStats(long postCount, String titles, IntSummaryStatistics likesStats){};
|
record PostCountTitlesLikesStats(long postCount, String titles, IntSummaryStatistics likesStats){};
|
||||||
record TitlesBoundedSumOfLikes(String titles, int boundedSumOfLikes) {};
|
record TitlesBoundedSumOfLikes(String titles, int boundedSumOfLikes) {};
|
||||||
|
|
||||||
public BlogPost(String title, String author, BlogPostType type, int likes) {
|
public BlogPost(String title, String author, BlogPostType type, int likes) {
|
||||||
this.title = title;
|
this.title = title;
|
||||||
this.author = author;
|
this.author = author;
|
||||||
|
|
|
@ -257,7 +257,7 @@ public class JavaGroupingByCollectorUnitTest {
|
||||||
@Test
|
@Test
|
||||||
public void givenListOfPosts_whenGroupedByAuthor_thenGetAMapUsingCollectingAndThen() {
|
public void givenListOfPosts_whenGroupedByAuthor_thenGetAMapUsingCollectingAndThen() {
|
||||||
|
|
||||||
Map<String, BlogPost.PostcountTitlesLikesStats> postsPerAuthor = posts.stream()
|
Map<String, BlogPost.PostCountTitlesLikesStats> postsPerAuthor = posts.stream()
|
||||||
.collect(groupingBy(BlogPost::getAuthor, collectingAndThen(toList(), list -> {
|
.collect(groupingBy(BlogPost::getAuthor, collectingAndThen(toList(), list -> {
|
||||||
long count = list.stream()
|
long count = list.stream()
|
||||||
.map(BlogPost::getTitle)
|
.map(BlogPost::getTitle)
|
||||||
|
@ -267,10 +267,10 @@ public class JavaGroupingByCollectorUnitTest {
|
||||||
.collect(joining(" : "));
|
.collect(joining(" : "));
|
||||||
IntSummaryStatistics summary = list.stream()
|
IntSummaryStatistics summary = list.stream()
|
||||||
.collect(summarizingInt(BlogPost::getLikes));
|
.collect(summarizingInt(BlogPost::getLikes));
|
||||||
return new BlogPost.PostcountTitlesLikesStats(count, titles, summary);
|
return new BlogPost.PostCountTitlesLikesStats(count, titles, summary);
|
||||||
})));
|
})));
|
||||||
|
|
||||||
BlogPost.PostcountTitlesLikesStats result = postsPerAuthor.get("Author 1");
|
BlogPost.PostCountTitlesLikesStats result = postsPerAuthor.get("Author 1");
|
||||||
assertThat(result.postCount()).isEqualTo(3L);
|
assertThat(result.postCount()).isEqualTo(3L);
|
||||||
assertThat(result.titles()).isEqualTo("News item 1 : Programming guide : Tech review 2");
|
assertThat(result.titles()).isEqualTo("News item 1 : Programming guide : Tech review 2");
|
||||||
assertThat(result.likesStats().getMax()).isEqualTo(20);
|
assertThat(result.likesStats().getMax()).isEqualTo(20);
|
||||||
|
@ -294,7 +294,7 @@ public class JavaGroupingByCollectorUnitTest {
|
||||||
.toUpperCase(),
|
.toUpperCase(),
|
||||||
u1.boundedSumOfLikes() + likes);
|
u1.boundedSumOfLikes() + likes);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
BlogPost.TitlesBoundedSumOfLikes result = postsPerAuthor.get("Author 1");
|
BlogPost.TitlesBoundedSumOfLikes result = postsPerAuthor.get("Author 1");
|
||||||
assertThat(result.titles()).isEqualTo("NEWS ITEM 1 : PROGRAMMING GUIDE : TECH REVIEW 2");
|
assertThat(result.titles()).isEqualTo("NEWS ITEM 1 : PROGRAMMING GUIDE : TECH REVIEW 2");
|
||||||
assertThat(result.boundedSumOfLikes()).isEqualTo(47);
|
assertThat(result.boundedSumOfLikes()).isEqualTo(47);
|
||||||
|
|
Loading…
Reference in New Issue