forked from TheAlgorithms/Java
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLevenshteinDistanceTest.java
More file actions
32 lines (26 loc) · 1.02 KB
/
LevenshteinDistanceTest.java
File metadata and controls
32 lines (26 loc) · 1.02 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
package com.thealgorithms.strings;
import org.junit.jupiter.api.Test;
import static org.assertj.core.api.Assertions.assertThat;
public class LevenshteinDistanceTest {
@Test
void sameStringsHaveZeroDistance() {
assertThat(LevenshteinDistance.compute("test", "test")).isZero();
}
@Test
void emptyToNonEmpty() {
assertThat(LevenshteinDistance.compute("", "abc")).isEqualTo(3);
assertThat(LevenshteinDistance.compute("abc", "")).isEqualTo(3);
}
@Test
void nullHandling() {
assertThat(LevenshteinDistance.compute(null, null)).isZero();
assertThat(LevenshteinDistance.compute(null, "abc")).isEqualTo(3);
assertThat(LevenshteinDistance.compute("abc", null)).isEqualTo(3);
}
@Test
void typicalExamples() {
assertThat(LevenshteinDistance.compute("kitten", "sitting")).isEqualTo(3);
assertThat(LevenshteinDistance.compute("flaw", "lawn")).isEqualTo(2);
assertThat(LevenshteinDistance.compute("gumbo", "gambol")).isEqualTo(2);
}
}