levenshtein_test.dart 1.1 KB

12345678910111213141516171819202122232425262728293031323334
  1. import 'package:appflowy/workspace/presentation/settings/widgets/levenshtein.dart';
  2. import 'package:flutter_test/flutter_test.dart';
  3. void main() {
  4. test('Levenshtein distance between identical strings', () {
  5. final distance = levenshtein('abc', 'abc');
  6. expect(distance, 0);
  7. });
  8. test('Levenshtein distance between strings of different lengths', () {
  9. final distance = levenshtein('kitten', 'sitting');
  10. expect(distance, 3);
  11. });
  12. test('Levenshtein distance between case-insensitive strings', () {
  13. final distance = levenshtein('Hello', 'hello', caseSensitive: false);
  14. expect(distance, 0);
  15. });
  16. test('Levenshtein distance between strings with substitutions', () {
  17. final distance = levenshtein('kitten', 'smtten');
  18. expect(distance, 2);
  19. });
  20. test('Levenshtein distance between strings with deletions', () {
  21. final distance = levenshtein('kitten', 'kiten');
  22. expect(distance, 1);
  23. });
  24. test('Levenshtein distance between strings with insertions', () {
  25. final distance = levenshtein('kitten', 'kitxten');
  26. expect(distance, 1);
  27. });
  28. }