252 lines
5.3 KiB
Go
252 lines
5.3 KiB
Go
|
package index
|
||
|
|
||
|
import (
|
||
|
"reflect"
|
||
|
"testing"
|
||
|
)
|
||
|
|
||
|
func BenchmarkSearchAllIndexes(b *testing.B) {
|
||
|
indexes = Index{
|
||
|
Dirs: make([]string, 0, 1000),
|
||
|
Files: make([]string, 0, 1000),
|
||
|
}
|
||
|
// Create mock data
|
||
|
createMockData(50, 3) // 1000 dirs, 3 files per dir
|
||
|
|
||
|
// Generate 100 random search terms
|
||
|
searchTerms := generateRandomSearchTerms(100)
|
||
|
|
||
|
b.ResetTimer()
|
||
|
b.ReportAllocs()
|
||
|
for i := 0; i < b.N; i++ {
|
||
|
// Execute the SearchAllIndexes function
|
||
|
for _, term := range searchTerms {
|
||
|
indexes.Search(term, "/", "test")
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// loop over test files and compare output
|
||
|
func TestParseSearch(t *testing.T) {
|
||
|
value := ParseSearch("my test search")
|
||
|
want := &SearchOptions{
|
||
|
Conditions: map[string]bool{
|
||
|
"exact": false,
|
||
|
},
|
||
|
Terms: []string{"my test search"},
|
||
|
}
|
||
|
if !reflect.DeepEqual(value, want) {
|
||
|
t.Fatalf("\n got: %+v\n want: %+v", value, want)
|
||
|
}
|
||
|
value = ParseSearch("case:exact my|test|search")
|
||
|
want = &SearchOptions{
|
||
|
Conditions: map[string]bool{
|
||
|
"exact": true,
|
||
|
},
|
||
|
Terms: []string{"my", "test", "search"},
|
||
|
}
|
||
|
if !reflect.DeepEqual(value, want) {
|
||
|
t.Fatalf("\n got: %+v\n want: %+v", value, want)
|
||
|
}
|
||
|
value = ParseSearch("type:largerThan=100 type:smallerThan=1000 test")
|
||
|
want = &SearchOptions{
|
||
|
Conditions: map[string]bool{
|
||
|
"exact": false,
|
||
|
"larger": true,
|
||
|
},
|
||
|
Terms: []string{"test"},
|
||
|
LargerThan: 100,
|
||
|
SmallerThan: 1000,
|
||
|
}
|
||
|
if !reflect.DeepEqual(value, want) {
|
||
|
t.Fatalf("\n got: %+v\n want: %+v", value, want)
|
||
|
}
|
||
|
value = ParseSearch("type:audio thisfile")
|
||
|
want = &SearchOptions{
|
||
|
Conditions: map[string]bool{
|
||
|
"exact": false,
|
||
|
"audio": true,
|
||
|
},
|
||
|
Terms: []string{"thisfile"},
|
||
|
}
|
||
|
if !reflect.DeepEqual(value, want) {
|
||
|
t.Fatalf("\n got: %+v\n want: %+v", value, want)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestSearchIndexes(t *testing.T) {
|
||
|
type args struct {
|
||
|
search string
|
||
|
scope string
|
||
|
sourceSession string
|
||
|
}
|
||
|
tests := []struct {
|
||
|
name string
|
||
|
args args
|
||
|
want []string
|
||
|
want1 map[string]map[string]bool
|
||
|
}{
|
||
|
// TODO: Add test cases.
|
||
|
}
|
||
|
for _, tt := range tests {
|
||
|
t.Run(tt.name, func(t *testing.T) {
|
||
|
got, got1 := indexes.Search(tt.args.search, tt.args.scope, tt.args.sourceSession)
|
||
|
if !reflect.DeepEqual(got, tt.want) {
|
||
|
t.Errorf("SearchAllIndexes() got = %v, want %v", got, tt.want)
|
||
|
}
|
||
|
if !reflect.DeepEqual(got1, tt.want1) {
|
||
|
t.Errorf("SearchAllIndexes() got1 = %v, want %v", got1, tt.want1)
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func Test_scopedPathNameFilter(t *testing.T) {
|
||
|
type args struct {
|
||
|
pathName string
|
||
|
scope string
|
||
|
}
|
||
|
tests := []struct {
|
||
|
name string
|
||
|
args args
|
||
|
want string
|
||
|
}{
|
||
|
// TODO: Add test cases.
|
||
|
}
|
||
|
for _, tt := range tests {
|
||
|
t.Run(tt.name, func(t *testing.T) {
|
||
|
if got := scopedPathNameFilter(tt.args.pathName, tt.args.scope); got != tt.want {
|
||
|
t.Errorf("scopedPathNameFilter() = %v, want %v", got, tt.want)
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func Test_containsSearchTerm(t *testing.T) {
|
||
|
type args struct {
|
||
|
pathName string
|
||
|
searchTerm string
|
||
|
options SearchOptions
|
||
|
isDir bool
|
||
|
}
|
||
|
tests := []struct {
|
||
|
name string
|
||
|
args args
|
||
|
want bool
|
||
|
want1 map[string]bool
|
||
|
}{
|
||
|
// TODO: Add test cases.
|
||
|
}
|
||
|
for _, tt := range tests {
|
||
|
t.Run(tt.name, func(t *testing.T) {
|
||
|
got, got1 := containsSearchTerm(tt.args.pathName, tt.args.searchTerm, tt.args.options, tt.args.isDir)
|
||
|
if got != tt.want {
|
||
|
t.Errorf("containsSearchTerm() got = %v, want %v", got, tt.want)
|
||
|
}
|
||
|
if !reflect.DeepEqual(got1, tt.want1) {
|
||
|
t.Errorf("containsSearchTerm() got1 = %v, want %v", got1, tt.want1)
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func Test_isDoc(t *testing.T) {
|
||
|
type args struct {
|
||
|
extension string
|
||
|
}
|
||
|
tests := []struct {
|
||
|
name string
|
||
|
args args
|
||
|
want bool
|
||
|
}{
|
||
|
// TODO: Add test cases.
|
||
|
}
|
||
|
for _, tt := range tests {
|
||
|
t.Run(tt.name, func(t *testing.T) {
|
||
|
if got := isDoc(tt.args.extension); got != tt.want {
|
||
|
t.Errorf("isDoc() = %v, want %v", got, tt.want)
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func Test_getFileSize(t *testing.T) {
|
||
|
type args struct {
|
||
|
filepath string
|
||
|
}
|
||
|
tests := []struct {
|
||
|
name string
|
||
|
args args
|
||
|
want int64
|
||
|
}{
|
||
|
// TODO: Add test cases.
|
||
|
}
|
||
|
for _, tt := range tests {
|
||
|
t.Run(tt.name, func(t *testing.T) {
|
||
|
if got := getFileSize(tt.args.filepath); got != tt.want {
|
||
|
t.Errorf("getFileSize() = %v, want %v", got, tt.want)
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func Test_isArchive(t *testing.T) {
|
||
|
type args struct {
|
||
|
extension string
|
||
|
}
|
||
|
tests := []struct {
|
||
|
name string
|
||
|
args args
|
||
|
want bool
|
||
|
}{
|
||
|
// TODO: Add test cases.
|
||
|
}
|
||
|
for _, tt := range tests {
|
||
|
t.Run(tt.name, func(t *testing.T) {
|
||
|
if got := isArchive(tt.args.extension); got != tt.want {
|
||
|
t.Errorf("isArchive() = %v, want %v", got, tt.want)
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func Test_getLastPathComponent(t *testing.T) {
|
||
|
type args struct {
|
||
|
path string
|
||
|
}
|
||
|
tests := []struct {
|
||
|
name string
|
||
|
args args
|
||
|
want string
|
||
|
}{
|
||
|
// TODO: Add test cases.
|
||
|
}
|
||
|
for _, tt := range tests {
|
||
|
t.Run(tt.name, func(t *testing.T) {
|
||
|
if got := getLastPathComponent(tt.args.path); got != tt.want {
|
||
|
t.Errorf("getLastPathComponent() = %v, want %v", got, tt.want)
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func Test_generateRandomHash(t *testing.T) {
|
||
|
type args struct {
|
||
|
length int
|
||
|
}
|
||
|
tests := []struct {
|
||
|
name string
|
||
|
args args
|
||
|
want string
|
||
|
}{
|
||
|
// TODO: Add test cases.
|
||
|
}
|
||
|
for _, tt := range tests {
|
||
|
t.Run(tt.name, func(t *testing.T) {
|
||
|
if got := generateRandomHash(tt.args.length); got != tt.want {
|
||
|
t.Errorf("generateRandomHash() = %v, want %v", got, tt.want)
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|