summaryrefslogtreecommitdiff
path: root/indexers/pikdex/index_test.go
blob: c49d67fa6431bb5bfd7b49f539da082962d42192 (plain)
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
package pikdex

import (
	"github.com/stretchr/testify/assert"
	"io/fs"
	"testing"
	"testing/fstest"
)

func TestUwudex_WantsWalk_AnyRoot(t *testing.T) {
	for _, r := range Roots {
		data := fstest.MapFS{
			r: &fstest.MapFile{
				Data: nil,
				Mode: fs.ModeDir,
			},
		}
		u := &pikdex{}
		result, root, err := u.WantsWalk(data)
		assert.Equal(t, root, r)
		assert.NoError(t, err)
		assert.True(t, result)
	}
}

func TestUwudex_WantsWalk_TwoRoots(t *testing.T) {
	data := fstest.MapFS{
		Roots[0]: &fstest.MapFile{
			Data: nil,
			Mode: fs.ModeDir,
		},
		Roots[1]: &fstest.MapFile{
			Data: nil,
			Mode: fs.ModeDir,
		},
	}
	u := &pikdex{}
	result, r, err := u.WantsWalk(data)
	// no guarantee we pick any one lol
	assert.Contains(t, Roots, r)
	assert.NoError(t, err)
	assert.True(t, result)
}

func TestUwudex_WantsWalk_NoRoots(t *testing.T) {
	data := fstest.MapFS{
		"asdf.txt": &fstest.MapFile{},
	}
	u := &pikdex{}
	result, r, err := u.WantsWalk(data)
	assert.Equal(t, "", r)
	assert.NoError(t, err)
	assert.False(t, result)
}