summaryrefslogtreecommitdiff
path: root/internal/hexaiaction
diff options
context:
space:
mode:
Diffstat (limited to 'internal/hexaiaction')
-rw-r--r--internal/hexaiaction/prompts_more_test.go19
-rw-r--r--internal/hexaiaction/run_more_test.go26
2 files changed, 45 insertions, 0 deletions
diff --git a/internal/hexaiaction/prompts_more_test.go b/internal/hexaiaction/prompts_more_test.go
new file mode 100644
index 0000000..62abc97
--- /dev/null
+++ b/internal/hexaiaction/prompts_more_test.go
@@ -0,0 +1,19 @@
+package hexaiaction
+
+import (
+ "context"
+ "strings"
+ "testing"
+
+ "codeberg.org/snonux/hexai/internal/llm"
+)
+
+type simpleDoer struct{ s string }
+
+func (d simpleDoer) Chat(_ context.Context, _ []llm.Message, _ ...llm.RequestOption) (string, error) { return d.s, nil }
+
+func TestRunOnce_StripsFences(t *testing.T) {
+ got, err := runOnce(context.Background(), simpleDoer{"```\nok\n```"}, "SYS", "USER")
+ if err != nil { t.Fatalf("runOnce: %v", err) }
+ if strings.TrimSpace(got) != "ok" { t.Fatalf("got %q", got) }
+}
diff --git a/internal/hexaiaction/run_more_test.go b/internal/hexaiaction/run_more_test.go
new file mode 100644
index 0000000..d7ab025
--- /dev/null
+++ b/internal/hexaiaction/run_more_test.go
@@ -0,0 +1,26 @@
+package hexaiaction
+
+import (
+ "bytes"
+ "context"
+ "os"
+ "testing"
+)
+
+// Covers the early error path in Run when no API key is available for the default provider.
+func TestRun_MissingAPIKey(t *testing.T) {
+ // Ensure no provider API keys in env
+ for _, k := range []string{"HEXAI_OPENAI_API_KEY", "OPENAI_API_KEY", "HEXAI_COPILOT_API_KEY", "COPILOT_API_KEY"} {
+ t.Setenv(k, "")
+ }
+ // Provide minimal stdin to get past empty input check (if reached)
+ in := bytes.NewBufferString("some selection text")
+ var out bytes.Buffer
+ var errBuf bytes.Buffer
+ // Expect an error due to missing OPENAI_API_KEY (default provider is openai)
+ if err := Run(context.Background(), in, &out, &errBuf); err == nil {
+ t.Fatal("expected error when API key is missing")
+ }
+ _ = os.Stderr
+}
+