mirror of
https://github.com/mariocandela/beelzebub.git
synced 2025-07-01 18:47:26 -04:00
288 lines
6.4 KiB
Go
288 lines
6.4 KiB
Go
![]() |
package plugins
|
||
|
|
||
|
import (
|
||
|
"github.com/go-resty/resty/v2"
|
||
|
"github.com/jarcoal/httpmock"
|
||
|
"github.com/mariocandela/beelzebub/v3/tracer"
|
||
|
"github.com/stretchr/testify/assert"
|
||
|
"net/http"
|
||
|
"testing"
|
||
|
)
|
||
|
|
||
|
const SystemPromptLen = 4
|
||
|
|
||
|
func TestBuildPromptEmptyHistory(t *testing.T) {
|
||
|
//Given
|
||
|
var histories []Message
|
||
|
command := "pwd"
|
||
|
|
||
|
//When
|
||
|
prompt, err := buildPrompt(histories, tracer.SSH, command)
|
||
|
|
||
|
//Then
|
||
|
assert.Nil(t, err)
|
||
|
assert.Equal(t, SystemPromptLen, len(prompt))
|
||
|
}
|
||
|
|
||
|
func TestBuildPromptWithHistory(t *testing.T) {
|
||
|
//Given
|
||
|
var histories = []Message{
|
||
|
{
|
||
|
Role: "cat hello.txt",
|
||
|
Content: "world",
|
||
|
},
|
||
|
}
|
||
|
|
||
|
command := "pwd"
|
||
|
|
||
|
//When
|
||
|
prompt, err := buildPrompt(histories, tracer.SSH, command)
|
||
|
|
||
|
//Then
|
||
|
assert.Nil(t, err)
|
||
|
assert.Equal(t, SystemPromptLen+1, len(prompt))
|
||
|
}
|
||
|
|
||
|
func TestBuildExecuteModelFailValidation(t *testing.T) {
|
||
|
|
||
|
llmHoneypot := LLMHoneypot{
|
||
|
Histories: make([]Message, 0),
|
||
|
OpenAIKey: "",
|
||
|
Protocol: tracer.SSH,
|
||
|
Model: GPT4O,
|
||
|
}
|
||
|
|
||
|
openAIGPTVirtualTerminal := InitLLMHoneypot(llmHoneypot)
|
||
|
|
||
|
_, err := openAIGPTVirtualTerminal.ExecuteModel("test")
|
||
|
|
||
|
assert.Equal(t, "openAIKey is empty", err.Error())
|
||
|
}
|
||
|
|
||
|
func TestBuildExecuteModelFailValidationStrategyType(t *testing.T) {
|
||
|
|
||
|
llmHoneypot := LLMHoneypot{
|
||
|
Histories: make([]Message, 0),
|
||
|
OpenAIKey: "",
|
||
|
Protocol: tracer.TCP,
|
||
|
Model: GPT4O,
|
||
|
}
|
||
|
|
||
|
openAIGPTVirtualTerminal := InitLLMHoneypot(llmHoneypot)
|
||
|
|
||
|
_, err := openAIGPTVirtualTerminal.ExecuteModel("test")
|
||
|
|
||
|
assert.Equal(t, "no prompt for protocol selected", err.Error())
|
||
|
}
|
||
|
|
||
|
func TestBuildExecuteModelFailValidationModelType(t *testing.T) {
|
||
|
// Given
|
||
|
llmHoneypot := LLMHoneypot{
|
||
|
Histories: make([]Message, 0),
|
||
|
Protocol: tracer.SSH,
|
||
|
Model: 5,
|
||
|
}
|
||
|
|
||
|
openAIGPTVirtualTerminal := InitLLMHoneypot(llmHoneypot)
|
||
|
|
||
|
//When
|
||
|
_, err := openAIGPTVirtualTerminal.ExecuteModel("ls")
|
||
|
|
||
|
//Then
|
||
|
assert.Errorf(t, err, "no model selected")
|
||
|
}
|
||
|
|
||
|
func TestBuildExecuteModelSSHWithResultsOpenAI(t *testing.T) {
|
||
|
client := resty.New()
|
||
|
httpmock.ActivateNonDefault(client.GetClient())
|
||
|
defer httpmock.DeactivateAndReset()
|
||
|
|
||
|
// Given
|
||
|
httpmock.RegisterResponder("POST", openAIGPTEndpoint,
|
||
|
func(req *http.Request) (*http.Response, error) {
|
||
|
resp, err := httpmock.NewJsonResponse(200, &Response{
|
||
|
Choices: []Choice{
|
||
|
{
|
||
|
Message: Message{
|
||
|
Role: SYSTEM.String(),
|
||
|
Content: "prova.txt",
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
})
|
||
|
if err != nil {
|
||
|
return httpmock.NewStringResponse(500, ""), nil
|
||
|
}
|
||
|
return resp, nil
|
||
|
},
|
||
|
)
|
||
|
|
||
|
llmHoneypot := LLMHoneypot{
|
||
|
Histories: make([]Message, 0),
|
||
|
OpenAIKey: "sdjdnklfjndslkjanfk",
|
||
|
Protocol: tracer.SSH,
|
||
|
Model: GPT4O,
|
||
|
}
|
||
|
|
||
|
openAIGPTVirtualTerminal := InitLLMHoneypot(llmHoneypot)
|
||
|
openAIGPTVirtualTerminal.client = client
|
||
|
|
||
|
//When
|
||
|
str, err := openAIGPTVirtualTerminal.ExecuteModel("ls")
|
||
|
|
||
|
//Then
|
||
|
assert.Nil(t, err)
|
||
|
assert.Equal(t, "prova.txt", str)
|
||
|
}
|
||
|
|
||
|
func TestBuildExecuteModelSSHWithResultsLLama(t *testing.T) {
|
||
|
client := resty.New()
|
||
|
httpmock.ActivateNonDefault(client.GetClient())
|
||
|
defer httpmock.DeactivateAndReset()
|
||
|
|
||
|
// Given
|
||
|
httpmock.RegisterResponder("POST", ollamaEndpoint,
|
||
|
func(req *http.Request) (*http.Response, error) {
|
||
|
resp, err := httpmock.NewJsonResponse(200, &Response{
|
||
|
Message: Message{
|
||
|
Role: SYSTEM.String(),
|
||
|
Content: "prova.txt",
|
||
|
},
|
||
|
})
|
||
|
if err != nil {
|
||
|
return httpmock.NewStringResponse(500, ""), nil
|
||
|
}
|
||
|
return resp, nil
|
||
|
},
|
||
|
)
|
||
|
|
||
|
llmHoneypot := LLMHoneypot{
|
||
|
Histories: make([]Message, 0),
|
||
|
Protocol: tracer.SSH,
|
||
|
Model: LLAMA3,
|
||
|
}
|
||
|
|
||
|
openAIGPTVirtualTerminal := InitLLMHoneypot(llmHoneypot)
|
||
|
openAIGPTVirtualTerminal.client = client
|
||
|
|
||
|
//When
|
||
|
str, err := openAIGPTVirtualTerminal.ExecuteModel("ls")
|
||
|
|
||
|
//Then
|
||
|
assert.Nil(t, err)
|
||
|
assert.Equal(t, "prova.txt", str)
|
||
|
}
|
||
|
|
||
|
func TestBuildExecuteModelSSHWithoutResults(t *testing.T) {
|
||
|
client := resty.New()
|
||
|
httpmock.ActivateNonDefault(client.GetClient())
|
||
|
defer httpmock.DeactivateAndReset()
|
||
|
|
||
|
// Given
|
||
|
httpmock.RegisterResponder("POST", openAIGPTEndpoint,
|
||
|
func(req *http.Request) (*http.Response, error) {
|
||
|
resp, err := httpmock.NewJsonResponse(200, &Response{
|
||
|
Choices: []Choice{},
|
||
|
})
|
||
|
if err != nil {
|
||
|
return httpmock.NewStringResponse(500, ""), nil
|
||
|
}
|
||
|
return resp, nil
|
||
|
},
|
||
|
)
|
||
|
|
||
|
llmHoneypot := LLMHoneypot{
|
||
|
Histories: make([]Message, 0),
|
||
|
OpenAIKey: "sdjdnklfjndslkjanfk",
|
||
|
Protocol: tracer.SSH,
|
||
|
Model: GPT4O,
|
||
|
}
|
||
|
|
||
|
openAIGPTVirtualTerminal := InitLLMHoneypot(llmHoneypot)
|
||
|
openAIGPTVirtualTerminal.client = client
|
||
|
|
||
|
//When
|
||
|
_, err := openAIGPTVirtualTerminal.ExecuteModel("ls")
|
||
|
|
||
|
//Then
|
||
|
assert.Equal(t, "no choices", err.Error())
|
||
|
}
|
||
|
|
||
|
func TestBuildExecuteModelHTTPWithResults(t *testing.T) {
|
||
|
client := resty.New()
|
||
|
httpmock.ActivateNonDefault(client.GetClient())
|
||
|
defer httpmock.DeactivateAndReset()
|
||
|
|
||
|
// Given
|
||
|
httpmock.RegisterResponder("POST", openAIGPTEndpoint,
|
||
|
func(req *http.Request) (*http.Response, error) {
|
||
|
resp, err := httpmock.NewJsonResponse(200, &Response{
|
||
|
Choices: []Choice{
|
||
|
{
|
||
|
Message: Message{
|
||
|
Role: SYSTEM.String(),
|
||
|
Content: "[default]\nregion = us-west-2\noutput = json",
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
})
|
||
|
if err != nil {
|
||
|
return httpmock.NewStringResponse(500, ""), nil
|
||
|
}
|
||
|
return resp, nil
|
||
|
},
|
||
|
)
|
||
|
|
||
|
llmHoneypot := LLMHoneypot{
|
||
|
Histories: make([]Message, 0),
|
||
|
OpenAIKey: "sdjdnklfjndslkjanfk",
|
||
|
Protocol: tracer.HTTP,
|
||
|
Model: GPT4O,
|
||
|
}
|
||
|
|
||
|
openAIGPTVirtualTerminal := InitLLMHoneypot(llmHoneypot)
|
||
|
openAIGPTVirtualTerminal.client = client
|
||
|
|
||
|
//When
|
||
|
str, err := openAIGPTVirtualTerminal.ExecuteModel("GET /.aws/credentials")
|
||
|
|
||
|
//Then
|
||
|
assert.Nil(t, err)
|
||
|
assert.Equal(t, "[default]\nregion = us-west-2\noutput = json", str)
|
||
|
}
|
||
|
|
||
|
func TestBuildExecuteModelHTTPWithoutResults(t *testing.T) {
|
||
|
client := resty.New()
|
||
|
httpmock.ActivateNonDefault(client.GetClient())
|
||
|
defer httpmock.DeactivateAndReset()
|
||
|
|
||
|
// Given
|
||
|
httpmock.RegisterResponder("POST", openAIGPTEndpoint,
|
||
|
func(req *http.Request) (*http.Response, error) {
|
||
|
resp, err := httpmock.NewJsonResponse(200, &Response{
|
||
|
Choices: []Choice{},
|
||
|
})
|
||
|
if err != nil {
|
||
|
return httpmock.NewStringResponse(500, ""), nil
|
||
|
}
|
||
|
return resp, nil
|
||
|
},
|
||
|
)
|
||
|
|
||
|
llmHoneypot := LLMHoneypot{
|
||
|
Histories: make([]Message, 0),
|
||
|
OpenAIKey: "sdjdnklfjndslkjanfk",
|
||
|
Protocol: tracer.HTTP,
|
||
|
Model: GPT4O,
|
||
|
}
|
||
|
|
||
|
openAIGPTVirtualTerminal := InitLLMHoneypot(llmHoneypot)
|
||
|
openAIGPTVirtualTerminal.client = client
|
||
|
|
||
|
//When
|
||
|
_, err := openAIGPTVirtualTerminal.ExecuteModel("GET /.aws/credentials")
|
||
|
|
||
|
//Then
|
||
|
assert.Equal(t, "no choices", err.Error())
|
||
|
}
|