mirror of
https://github.com/Pull-Pal/pull-pal.git
synced 2024-11-10 14:26:18 -05:00
9678a1c961
* Parsing issue into llm request moved to `vc` package * Converted "issue ID" string to "issue number" int * Added config struct to `pullpal/common.go` * Added multi-repo config support * Added support for custom base branches for PRs * Added configurable wait time * Bot should comment on pull requests and threads when running into an error
141 lines
4.6 KiB
Go
141 lines
4.6 KiB
Go
package pullpal
|
|
|
|
import (
|
|
"github.com/mobyvb/pull-pal/llm"
|
|
"github.com/mobyvb/pull-pal/vc"
|
|
"github.com/sashabaranov/go-openai"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
func (p *PullPal) DebugGit() error {
|
|
p.log.Info("Starting Pull Pal git debug")
|
|
r := p.repos[0]
|
|
|
|
// create commit with file changes
|
|
err := r.localGitClient.StartCommit()
|
|
//err = p.ghClient.StartCommit()
|
|
if err != nil {
|
|
r.log.Error("error starting commit", zap.Error(err))
|
|
return err
|
|
}
|
|
newBranchName := "debug-branch"
|
|
|
|
for _, f := range []string{"a", "b"} {
|
|
err = r.localGitClient.ReplaceOrAddLocalFile(llm.File{
|
|
Path: f,
|
|
Contents: "hello",
|
|
})
|
|
if err != nil {
|
|
r.log.Error("error replacing or adding file", zap.Error(err))
|
|
return err
|
|
}
|
|
}
|
|
|
|
commitMessage := "debug commit message"
|
|
err = r.localGitClient.FinishCommit(commitMessage)
|
|
if err != nil {
|
|
r.log.Error("error finishing commit", zap.Error(err))
|
|
return err
|
|
}
|
|
|
|
err = r.localGitClient.PushBranch(newBranchName)
|
|
if err != nil {
|
|
r.log.Error("error pushing branch", zap.Error(err))
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// todo dont require args for listing comments
|
|
func (p *PullPal) DebugGithub(handles []string) error {
|
|
p.log.Info("Starting Pull Pal Github debug")
|
|
r := p.repos[0]
|
|
|
|
issues, err := r.ghClient.ListOpenIssues(r.listIssueOptions)
|
|
if err != nil {
|
|
r.log.Error("error listing issues", zap.Error(err))
|
|
return err
|
|
}
|
|
for _, i := range issues {
|
|
r.log.Info("got issue", zap.String("issue", i.String()))
|
|
}
|
|
|
|
comments, err := r.ghClient.ListOpenComments(vc.ListCommentOptions{
|
|
Handles: handles,
|
|
})
|
|
if err != nil {
|
|
r.log.Error("error listing comments", zap.Error(err))
|
|
return err
|
|
}
|
|
for _, c := range comments {
|
|
r.log.Info("got comment", zap.String("comment", c.String()))
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (p *PullPal) DebugLLM() error {
|
|
p.log.Info("Starting Pull Pal llm debug")
|
|
|
|
file := llm.File{
|
|
Path: "main.go",
|
|
Contents: `package main\n\nimport (\n "net/http"\n)\n\nfunc main() {\n fs := http.FileServer(http.Dir("static"))\n http.Handle("/", fs)\n\n http.ListenAndServe(":7777", nil)\n}\n\n\n \n\n \n `,
|
|
}
|
|
|
|
codeChangeRequest := llm.CodeChangeRequest{
|
|
Files: []llm.File{file},
|
|
Subject: "update port and add endpoint",
|
|
Body: "use port 8080 for the server in main.go. Also add an endpoint at GET /api/numbers that returns a random integer between 2 and 10",
|
|
IssueNumber: 1234,
|
|
}
|
|
|
|
p.log.Info("CODE CHANGE REQUEST", zap.String("request", codeChangeRequest.String()))
|
|
|
|
diffCommentRequestChange := llm.DiffCommentRequest{
|
|
File: file,
|
|
Contents: "remove this unnecessary whitespace at the end",
|
|
Diff: "@@ -0,0 +1,15 @@\n+package main\n+ \n+ import (\n+ \"net/http\"\n+ )\n+ \n+ func main() {\n+ fs := http.FileServer(http.Dir(\"static\"))\n+ http.Handle(\"/\", fs)\n+ \n+ http.ListenAndServe(\":7777\", nil)\n+ }\n+",
|
|
}
|
|
p.log.Info("DIFF COMMENT REQUEST CODECHANGE", zap.String("request", diffCommentRequestChange.String()))
|
|
|
|
diffCommentRequestQuestion := llm.DiffCommentRequest{
|
|
File: file,
|
|
Contents: "what does this Handle line do?",
|
|
Diff: "@@ -0,0 +1,15 @@\n+package main\n+ \n+ import (\n+ \"net/http\"\n+ )\n+ \n+ func main() {\n+ fs := http.FileServer(http.Dir(\"static\"))\n+ http.Handle(\"/\", fs)\n",
|
|
}
|
|
p.log.Info("DIFF COMMENT REQUEST QUESTION", zap.String("request", diffCommentRequestQuestion.String()))
|
|
|
|
for _, m := range []string{openai.GPT3Dot5Turbo, openai.GPT4} {
|
|
p.log.Info("testing with openai api", zap.String("MODEL", m))
|
|
|
|
p.log.Info("testing code change request")
|
|
res, err := p.openAIClient.EvaluateCCR(p.ctx, m, codeChangeRequest)
|
|
if err != nil {
|
|
p.log.Error("error evaluating code change request for model", zap.Error(err))
|
|
continue
|
|
}
|
|
p.log.Info("openai api response", zap.String("model", m), zap.String("response", res.String()))
|
|
|
|
p.log.Info("testing diff comment code change request")
|
|
diffRes, err := p.openAIClient.EvaluateDiffComment(p.ctx, m, diffCommentRequestChange)
|
|
if err != nil {
|
|
p.log.Error("error evaluating diff comment request for model", zap.Error(err))
|
|
continue
|
|
}
|
|
p.log.Info("openai api response", zap.String("model", m), zap.String("response", diffRes.String()))
|
|
|
|
p.log.Info("testing diff comment question request")
|
|
diffRes, err = p.openAIClient.EvaluateDiffComment(p.ctx, m, diffCommentRequestQuestion)
|
|
if err != nil {
|
|
p.log.Error("error evaluating diff comment request for model", zap.Error(err))
|
|
continue
|
|
}
|
|
p.log.Info("openai api response", zap.String("model", m), zap.String("response", diffRes.String()))
|
|
|
|
}
|
|
|
|
// TODO group errors and return
|
|
return nil
|
|
}
|