Merge pull request #12490 from hkhan/JAVA-13290-sync-article-code

[JAVA-13290] Update record name
This commit is contained in:
kwoyke 2022-07-14 13:08:24 +02:00 committed by GitHub
commit 3db189f71a
2 changed files with 7 additions and 7 deletions

View File

@ -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;

View File

@ -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);