aboutsummaryrefslogtreecommitdiff
path: root/levenshtein/strings_test.go
blob: fe103e4bfaab9ce6c068e7749793599f95e3ef0f (plain) (blame)
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package levenshtein

import (
	"reflect"
	"testing"
)

func TestString(t *testing.T) {
	type args struct {
		s1 string
		s2 string
	}
	tests := []struct {
		name string
		args args
		want []Edit
	}{
		{
			name: "test1",
			args: args{
				s1: "абвзгде",
				s2: "абвжгде",
			},
			want: []Edit{
				{
					Type: Replace,
					Idx1: 3,
					Idx2: 3,
				},
			},
		},
		{
			name: "test2",
			args: args{
				s1: "абавзгд",
				s2: "абввжгде",
			},
			want: []Edit{
				{
					Type: Insert, // абавзгд -> абавзгд[е]
					Idx1: 6,
					Idx2: 7,
				},
				{
					Type: Replace, // абав[з]где -> абав[ж]где
					Idx1: 4,
					Idx2: 4,
				},
				{
					Type: Replace, // аб[а]вжгде -> аб[в]вжгде
					Idx1: 2,
					Idx2: 2,
				},
			},
		},
	}
	for _, tt := range tests {
		t.Run(tt.name, func(t *testing.T) {
			if got := String(tt.args.s1, tt.args.s2); !reflect.DeepEqual(got, tt.want) {
				t.Errorf("LevenshteinString() = %v, want %v", got, tt.want)
			}
		})
	}
}