2024-01-05 15:13:08 -05:00
|
|
|
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"})
|
2024-01-07 18:48:05 -05:00
|
|
|
assert.Len(t, res, 1)
|
2024-01-05 15:13:08 -05:00
|
|
|
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"})
|
2024-01-07 18:48:05 -05:00
|
|
|
assert.Len(t, res, 3)
|
2024-01-05 15:13:08 -05:00
|
|
|
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"})
|
2024-01-07 18:48:05 -05:00
|
|
|
assert.Len(t, res, 3)
|
2024-01-05 15:13:08 -05:00
|
|
|
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"})
|
2024-01-07 18:48:05 -05:00
|
|
|
assert.Len(t, res, 1)
|
2024-01-05 15:13:08 -05:00
|
|
|
assert.Equal(t, availableShims["cpu"], res[0])
|
|
|
|
|
|
|
|
res = getShims(gpu.GpuInfo{Library: "default"})
|
2024-01-07 18:48:05 -05:00
|
|
|
assert.Len(t, res, 1)
|
|
|
|
assert.Equal(t, "default", res[0])
|
2024-01-05 15:13:08 -05:00
|
|
|
|
|
|
|
availableShims = map[string]string{
|
|
|
|
"rocm": "X_rocm_v5",
|
|
|
|
"cpu": "X_cpu",
|
|
|
|
}
|
|
|
|
assert.Equal(t, true, rocmShimPresent())
|
|
|
|
res = getShims(gpu.GpuInfo{Library: "rocm", Variant: "v6"})
|
2024-01-07 18:48:05 -05:00
|
|
|
assert.Len(t, res, 2)
|
2024-01-05 15:13:08 -05:00
|
|
|
assert.Equal(t, availableShims["rocm"], res[0])
|
|
|
|
assert.Equal(t, availableShims["cpu"], res[1])
|
|
|
|
}
|