payload_test.go 1.67 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
package llm

import (
	"testing"

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

func TestGetDynLibs(t *testing.T) {
	availableDynLibs = map[string]string{
		"cpu": "X_cpu",
	}
	assert.Equal(t, false, rocmDynLibPresent())
	res := getDynLibs(gpu.GpuInfo{Library: "cpu"})
	assert.Len(t, res, 1)
	assert.Equal(t, availableDynLibs["cpu"], res[0])

19
20
21
22
	variant := gpu.GetCPUVariant()
	if variant != "" {
		variant = "_" + variant
	}
23
	availableDynLibs = map[string]string{
24
25
26
		"rocm_v5":       "X_rocm_v5",
		"rocm_v6":       "X_rocm_v6",
		"cpu" + variant: "X_cpu",
27
28
29
30
31
32
	}
	assert.Equal(t, true, rocmDynLibPresent())
	res = getDynLibs(gpu.GpuInfo{Library: "rocm"})
	assert.Len(t, res, 3)
	assert.Equal(t, availableDynLibs["rocm_v5"], res[0])
	assert.Equal(t, availableDynLibs["rocm_v6"], res[1])
33
	assert.Equal(t, availableDynLibs["cpu"+variant], res[2])
34
35
36
37
38

	res = getDynLibs(gpu.GpuInfo{Library: "rocm", Variant: "v6"})
	assert.Len(t, res, 3)
	assert.Equal(t, availableDynLibs["rocm_v6"], res[0])
	assert.Equal(t, availableDynLibs["rocm_v5"], res[1])
39
	assert.Equal(t, availableDynLibs["cpu"+variant], res[2])
40
41
42

	res = getDynLibs(gpu.GpuInfo{Library: "cuda"})
	assert.Len(t, res, 1)
43
	assert.Equal(t, availableDynLibs["cpu"+variant], res[0])
44
45
46
47
48
49

	res = getDynLibs(gpu.GpuInfo{Library: "default"})
	assert.Len(t, res, 1)
	assert.Equal(t, "default", res[0])

	availableDynLibs = map[string]string{
50
51
		"rocm":          "X_rocm_v5",
		"cpu" + variant: "X_cpu",
52
53
54
55
56
	}
	assert.Equal(t, true, rocmDynLibPresent())
	res = getDynLibs(gpu.GpuInfo{Library: "rocm", Variant: "v6"})
	assert.Len(t, res, 2)
	assert.Equal(t, availableDynLibs["rocm"], res[0])
57
	assert.Equal(t, availableDynLibs["cpu"+variant], res[1])
58
}