2023-04-21 22:44:52 +00:00
|
|
|
package api_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
. "github.com/go-skynet/LocalAI/api"
|
|
|
|
"github.com/go-skynet/LocalAI/pkg/model"
|
|
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
. "github.com/onsi/ginkgo/v2"
|
|
|
|
. "github.com/onsi/gomega"
|
|
|
|
|
2023-04-29 07:22:09 +00:00
|
|
|
openaigo "github.com/otiai10/openaigo"
|
2023-04-21 22:44:52 +00:00
|
|
|
"github.com/sashabaranov/go-openai"
|
|
|
|
)
|
|
|
|
|
|
|
|
var _ = Describe("API test", func() {
|
|
|
|
|
|
|
|
var app *fiber.App
|
|
|
|
var modelLoader *model.ModelLoader
|
|
|
|
var client *openai.Client
|
2023-04-29 07:22:09 +00:00
|
|
|
var client2 *openaigo.Client
|
2023-04-21 22:44:52 +00:00
|
|
|
Context("API query", func() {
|
|
|
|
BeforeEach(func() {
|
|
|
|
modelLoader = model.NewModelLoader(os.Getenv("MODELS_PATH"))
|
2023-04-27 04:18:18 +00:00
|
|
|
app = App("", modelLoader, 1, 512, false, true, true)
|
2023-04-21 22:44:52 +00:00
|
|
|
go app.Listen("127.0.0.1:9090")
|
|
|
|
|
|
|
|
defaultConfig := openai.DefaultConfig("")
|
|
|
|
defaultConfig.BaseURL = "http://127.0.0.1:9090/v1"
|
|
|
|
|
2023-04-29 07:22:09 +00:00
|
|
|
client2 = openaigo.NewClient("")
|
|
|
|
client2.BaseURL = defaultConfig.BaseURL
|
|
|
|
|
2023-04-21 22:44:52 +00:00
|
|
|
// Wait for API to be ready
|
|
|
|
client = openai.NewClientWithConfig(defaultConfig)
|
|
|
|
Eventually(func() error {
|
|
|
|
_, err := client.ListModels(context.TODO())
|
|
|
|
return err
|
|
|
|
}, "2m").ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
AfterEach(func() {
|
|
|
|
app.Shutdown()
|
|
|
|
})
|
|
|
|
It("returns the models list", func() {
|
|
|
|
models, err := client.ListModels(context.TODO())
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
2023-04-27 04:18:18 +00:00
|
|
|
Expect(len(models.Models)).To(Equal(3))
|
2023-04-21 22:44:52 +00:00
|
|
|
Expect(models.Models[0].ID).To(Equal("testmodel"))
|
|
|
|
})
|
|
|
|
It("can generate completions", func() {
|
|
|
|
resp, err := client.CreateCompletion(context.TODO(), openai.CompletionRequest{Model: "testmodel", Prompt: "abcdedfghikl"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(len(resp.Choices)).To(Equal(1))
|
|
|
|
Expect(resp.Choices[0].Text).ToNot(BeEmpty())
|
|
|
|
})
|
2023-04-27 04:18:18 +00:00
|
|
|
|
|
|
|
It("can generate chat completions ", func() {
|
|
|
|
resp, err := client.CreateChatCompletion(context.TODO(), openai.ChatCompletionRequest{Model: "testmodel", Messages: []openai.ChatCompletionMessage{openai.ChatCompletionMessage{Role: "user", Content: "abcdedfghikl"}}})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(len(resp.Choices)).To(Equal(1))
|
|
|
|
Expect(resp.Choices[0].Message.Content).ToNot(BeEmpty())
|
|
|
|
})
|
|
|
|
|
|
|
|
It("can generate completions from model configs", func() {
|
|
|
|
resp, err := client.CreateCompletion(context.TODO(), openai.CompletionRequest{Model: "gpt4all", Prompt: "abcdedfghikl"})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(len(resp.Choices)).To(Equal(1))
|
|
|
|
Expect(resp.Choices[0].Text).ToNot(BeEmpty())
|
|
|
|
})
|
|
|
|
|
|
|
|
It("can generate chat completions from model configs", func() {
|
|
|
|
resp, err := client.CreateChatCompletion(context.TODO(), openai.ChatCompletionRequest{Model: "gpt4all-2", Messages: []openai.ChatCompletionMessage{openai.ChatCompletionMessage{Role: "user", Content: "abcdedfghikl"}}})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(len(resp.Choices)).To(Equal(1))
|
|
|
|
Expect(resp.Choices[0].Message.Content).ToNot(BeEmpty())
|
|
|
|
})
|
|
|
|
|
2023-04-24 21:42:03 +00:00
|
|
|
It("returns errors", func() {
|
|
|
|
_, err := client.CreateCompletion(context.TODO(), openai.CompletionRequest{Model: "foomodel", Prompt: "abcdedfghikl"})
|
|
|
|
Expect(err).To(HaveOccurred())
|
2023-05-11 14:34:16 +00:00
|
|
|
Expect(err.Error()).To(ContainSubstring("error, status code: 500, message: could not load model - all backends returned error: 9 errors occurred:"))
|
2023-04-24 21:42:03 +00:00
|
|
|
})
|
2023-04-27 04:18:18 +00:00
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
Context("Config file", func() {
|
|
|
|
BeforeEach(func() {
|
|
|
|
modelLoader = model.NewModelLoader(os.Getenv("MODELS_PATH"))
|
|
|
|
app = App(os.Getenv("CONFIG_FILE"), modelLoader, 1, 512, false, true, true)
|
|
|
|
go app.Listen("127.0.0.1:9090")
|
|
|
|
|
|
|
|
defaultConfig := openai.DefaultConfig("")
|
|
|
|
defaultConfig.BaseURL = "http://127.0.0.1:9090/v1"
|
2023-04-29 07:22:09 +00:00
|
|
|
client2 = openaigo.NewClient("")
|
|
|
|
client2.BaseURL = defaultConfig.BaseURL
|
2023-04-27 04:18:18 +00:00
|
|
|
// Wait for API to be ready
|
|
|
|
client = openai.NewClientWithConfig(defaultConfig)
|
|
|
|
Eventually(func() error {
|
|
|
|
_, err := client.ListModels(context.TODO())
|
|
|
|
return err
|
|
|
|
}, "2m").ShouldNot(HaveOccurred())
|
|
|
|
})
|
|
|
|
AfterEach(func() {
|
|
|
|
app.Shutdown()
|
|
|
|
})
|
|
|
|
It("can generate chat completions from config file", func() {
|
|
|
|
|
|
|
|
models, err := client.ListModels(context.TODO())
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(len(models.Models)).To(Equal(5))
|
|
|
|
Expect(models.Models[0].ID).To(Equal("testmodel"))
|
|
|
|
})
|
|
|
|
It("can generate chat completions from config file", func() {
|
|
|
|
resp, err := client.CreateChatCompletion(context.TODO(), openai.ChatCompletionRequest{Model: "list1", Messages: []openai.ChatCompletionMessage{openai.ChatCompletionMessage{Role: "user", Content: "abcdedfghikl"}}})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(len(resp.Choices)).To(Equal(1))
|
|
|
|
Expect(resp.Choices[0].Message.Content).ToNot(BeEmpty())
|
|
|
|
})
|
|
|
|
It("can generate chat completions from config file", func() {
|
|
|
|
resp, err := client.CreateChatCompletion(context.TODO(), openai.ChatCompletionRequest{Model: "list2", Messages: []openai.ChatCompletionMessage{openai.ChatCompletionMessage{Role: "user", Content: "abcdedfghikl"}}})
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(len(resp.Choices)).To(Equal(1))
|
|
|
|
Expect(resp.Choices[0].Message.Content).ToNot(BeEmpty())
|
|
|
|
})
|
2023-04-29 07:22:09 +00:00
|
|
|
It("can generate edit completions from config file", func() {
|
|
|
|
request := openaigo.EditCreateRequestBody{
|
|
|
|
Model: "list2",
|
|
|
|
Instruction: "foo",
|
|
|
|
Input: "bar",
|
|
|
|
}
|
|
|
|
resp, err := client2.CreateEdit(context.Background(), request)
|
|
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
Expect(len(resp.Choices)).To(Equal(1))
|
|
|
|
Expect(resp.Choices[0].Text).ToNot(BeEmpty())
|
|
|
|
})
|
2023-04-21 22:44:52 +00:00
|
|
|
})
|
|
|
|
})
|