shim_test.go 1.48 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
package llm

import (
	"testing"

	"github.com/jmorganca/ollama/gpu"
	"github.com/stretchr/testify/assert"
)

func TestGetShims(t *testing.T) {
	availableShims = map[string]string{
		"cpu": "X_cpu",
	}
	assert.Equal(t, false, rocmShimPresent())
	res := getShims(gpu.GpuInfo{Library: "cpu"})
16
	assert.Len(t, res, 1)
17
18
19
20
21
22
23
24
25
	assert.Equal(t, availableShims["cpu"], res[0])

	availableShims = map[string]string{
		"rocm_v5": "X_rocm_v5",
		"rocm_v6": "X_rocm_v6",
		"cpu":     "X_cpu",
	}
	assert.Equal(t, true, rocmShimPresent())
	res = getShims(gpu.GpuInfo{Library: "rocm"})
26
	assert.Len(t, res, 3)
27
28
29
30
31
	assert.Equal(t, availableShims["rocm_v5"], res[0])
	assert.Equal(t, availableShims["rocm_v6"], res[1])
	assert.Equal(t, availableShims["cpu"], res[2])

	res = getShims(gpu.GpuInfo{Library: "rocm", Variant: "v6"})
32
	assert.Len(t, res, 3)
33
34
35
36
37
	assert.Equal(t, availableShims["rocm_v6"], res[0])
	assert.Equal(t, availableShims["rocm_v5"], res[1])
	assert.Equal(t, availableShims["cpu"], res[2])

	res = getShims(gpu.GpuInfo{Library: "cuda"})
38
	assert.Len(t, res, 1)
39
40
41
	assert.Equal(t, availableShims["cpu"], res[0])

	res = getShims(gpu.GpuInfo{Library: "default"})
42
43
	assert.Len(t, res, 1)
	assert.Equal(t, "default", res[0])
44
45
46
47
48
49
50

	availableShims = map[string]string{
		"rocm": "X_rocm_v5",
		"cpu":  "X_cpu",
	}
	assert.Equal(t, true, rocmShimPresent())
	res = getShims(gpu.GpuInfo{Library: "rocm", Variant: "v6"})
51
	assert.Len(t, res, 2)
52
53
54
	assert.Equal(t, availableShims["rocm"], res[0])
	assert.Equal(t, availableShims["cpu"], res[1])
}