package de.juplo.kafka.wordcount.query;
-import com.fasterxml.jackson.databind.ObjectMapper;
import de.juplo.kafka.wordcount.top10.TestEntry;
import de.juplo.kafka.wordcount.top10.TestRanking;
+import de.juplo.kafka.wordcount.top10.TestUser;
import de.juplo.kafka.wordcount.users.TestUserData;
import org.apache.kafka.streams.KeyValue;
import java.util.function.Function;
import java.util.stream.Stream;
+import static de.juplo.kafka.wordcount.query.QueryStreamProcessor.STATS_TYPE;
import static org.assertj.core.api.Assertions.assertThat;
class TestData
{
- static final ObjectMapper objectMapper = new ObjectMapper();
- static final String PETER = "peter";
- static final String KLAUS = "klaus";
+ static final TestUser PETER = TestUser.of(STATS_TYPE, "peter");
+ static final TestUser KLAUS = TestUser.of(STATS_TYPE, "klaus");
+ static final TestUser OTHER_CHANNEL = TestUser.of("POPULAR", "klaus");
- static final Stream<KeyValue<String, TestRanking>> getTop10Messages()
+ static final Stream<KeyValue<TestUser, TestRanking>> getTop10Messages()
{
return Stream.of(TOP10_MESSAGES);
}
return Stream.of(USERS_MESSAGES);
}
- static void assertExpectedState(Function<String, String> function)
+ static void assertExpectedState(Function<String, UserRanking> function)
{
- assertRankingEqualsRankingFromLastMessage(PETER, function.apply(PETER));
- assertRankingEqualsRankingFromLastMessage(KLAUS, function.apply(KLAUS));
+ assertRankingEqualsRankingFromLastMessage(PETER.getChannel(), function.apply(PETER.getChannel()));
+ assertRankingEqualsRankingFromLastMessage(KLAUS.getChannel(), function.apply(KLAUS.getChannel()));
}
- private static void assertRankingEqualsRankingFromLastMessage(String user, String userRankingJson)
+ private static void assertRankingEqualsRankingFromLastMessage(String user, UserRanking rankingJson)
{
- assertThat(userRankingOf(userRankingJson)).isEqualTo(getLastMessageFor(user));
- }
-
- private static UserRanking userRankingOf(String json)
- {
- if (json == null)
- {
- return null;
- }
-
- try
- {
- return objectMapper.readValue(json, UserRanking.class);
- }
- catch (Exception e)
- {
- throw new RuntimeException(e);
- }
+ assertThat(rankingJson).isEqualTo(getLastMessageFor(user));
}
private static UserRanking getLastMessageFor(String user)
{
return getTop10Messages()
- .filter(kv -> kv.key.equals(user))
+ .filter(kv -> kv.key.getChannel().equals(user))
.map(kv -> kv.value)
.map(testRanking -> userRankingFor(user, testRanking))
.reduce(null, (left, right) -> right);
private static Entry entryOf(TestEntry testEntry)
{
Entry entry = new Entry();
- entry.setWord(testEntry.getWord());
- entry.setCount(testEntry.getCount());
+ entry.setKey(testEntry.getKey());
+ entry.setCounter(testEntry.getCounter());
return entry;
}
-
- private static KeyValue<String, TestRanking>[] TOP10_MESSAGES = new KeyValue[]
+ private static KeyValue<TestUser, TestRanking>[] TOP10_MESSAGES = new KeyValue[]
{
KeyValue.pair( // 0
PETER,
KLAUS,
TestRanking.of(
TestEntry.of("Müsch", 1l))),
+ KeyValue.pair( // 1
+ OTHER_CHANNEL,
+ TestRanking.of(
+ TestEntry.of("Müsch", 1l))),
KeyValue.pair( // 2
PETER,
TestRanking.of(
TestRanking.of(
TestEntry.of("Müsch", 2l),
TestEntry.of("s", 2l))),
+ KeyValue.pair( // 8
+ OTHER_CHANNEL,
+ TestRanking.of(
+ TestEntry.of("Müsch", 2l),
+ TestEntry.of("s", 2l))),
KeyValue.pair( // 9
PETER,
TestRanking.of(
private static KeyValue<String, TestUserData>[] USERS_MESSAGES = new KeyValue[]
{
KeyValue.pair(
- PETER,
- TestUserData.of(PETER, "Peter", "Pan", TestUserData.Sex.MALE)),
+ PETER.getChannel(),
+ TestUserData.of(PETER.getChannel(), "Peter", "Pan", TestUserData.Sex.MALE)),
KeyValue.pair(
- KLAUS,
- TestUserData.of(KLAUS, "Klaus", "Klüse", TestUserData.Sex.OTHER)),
+ KLAUS.getChannel(),
+ TestUserData.of(KLAUS.getChannel(), "Klaus", "Klüse", TestUserData.Sex.OTHER)),
};
}