From 5e182d40de78353526cc31e7116ffcfdabe6e1a7 Mon Sep 17 00:00:00 2001 From: Greg Price Date: Sun, 8 Dec 2024 00:44:29 -0800 Subject: [PATCH] emoji test [nfc]: Tighten query-matches tests This makes these tests a bit easier to read already, with less noisy repetition; and it prepares them for adding more complexity to how this matching works. --- test/model/emoji_test.dart | 32 +++++++++++++++----------------- 1 file changed, 15 insertions(+), 17 deletions(-) diff --git a/test/model/emoji_test.dart b/test/model/emoji_test.dart index 9ad49ba2e2..af7be3eb1a 100644 --- a/test/model/emoji_test.dart +++ b/test/model/emoji_test.dart @@ -283,8 +283,12 @@ void main() { emojiUnicode: tryParseEmojiCodeToUnicode(emojiCode)!)); } + bool matches(String query, EmojiCandidate candidate) { + return EmojiAutocompleteQuery(query).matches(candidate); + } + bool matchesNames(String query, List names) { - return EmojiAutocompleteQuery(query).matches(unicode(names)); + return matches(query, unicode(names)); } bool matchesName(String query, String emojiName) { @@ -354,8 +358,7 @@ void main() { test('query matches literal Unicode value', () { bool matchesLiteral(String query, String emojiCode, {required String aka}) { assert(aka == query); - return EmojiAutocompleteQuery(query) - .matches(unicode(['asdf'], emojiCode: emojiCode)); + return matches(query, unicode(['asdf'], emojiCode: emojiCode)); } // Matching the code, in hex, doesn't count. @@ -389,16 +392,11 @@ void main() { resolvedStillUrl: eg.realmUrl.resolve('/emoji/1-still.png'))); } - check(EmojiAutocompleteQuery('eqeq') - .matches(realmCandidate('eqeq'))).isTrue(); - check(EmojiAutocompleteQuery('open_') - .matches(realmCandidate('open_book'))).isTrue(); - check(EmojiAutocompleteQuery('n_b') - .matches(realmCandidate('open_book'))).isFalse(); - check(EmojiAutocompleteQuery('blue dia') - .matches(realmCandidate('large_blue_diamond'))).isTrue(); - check(EmojiAutocompleteQuery('Smi') - .matches(realmCandidate('smile'))).isTrue(); + check(matches('eqeq', realmCandidate('eqeq'))).isTrue(); + check(matches('open_', realmCandidate('open_book'))).isTrue(); + check(matches('n_b', realmCandidate('open_book'))).isFalse(); + check(matches('blue dia', realmCandidate('large_blue_diamond'))).isTrue(); + check(matches('Smi', realmCandidate('smile'))).isTrue(); }); test('can match Zulip extra emoji', () { @@ -410,10 +408,10 @@ void main() { emojiType: ReactionType.zulipExtraEmoji, emojiCode: 'zulip', emojiName: 'zulip')); - check(EmojiAutocompleteQuery('z').matches(zulipCandidate)).isTrue(); - check(EmojiAutocompleteQuery('Zulip').matches(zulipCandidate)).isTrue(); - check(EmojiAutocompleteQuery('p').matches(zulipCandidate)).isTrue(); - check(EmojiAutocompleteQuery('x').matches(zulipCandidate)).isFalse(); + check(matches('z', zulipCandidate)).isTrue(); + check(matches('Zulip', zulipCandidate)).isTrue(); + check(matches('p', zulipCandidate)).isTrue(); + check(matches('x', zulipCandidate)).isFalse(); }); }); }