Add test coverage improvements (+2.7% overall)
- cmd/bd: 20.4% → 21.1% (+0.7%)
- Added tests for helper functions: isBoundary, isNumeric,
extractPrefix, getPrefixList, parseLabelArgs, replaceBoundaryAware
- New files: helpers_test.go, simple_helpers_test.go
- internal/rpc: 46.6% → 58.0% (+11.4%)
- Added tests for 11 RPC client methods: SetTimeout, Show, Ready,
Stats, AddDependency, RemoveDependency, AddLabel, RemoveLabel,
Batch, ReposList, ReposReady
- New file: coverage_test.go
Overall coverage: 46.0% → 48.7%
Target: 75% (bd-136)
Amp-Thread-ID: https://ampcode.com/threads/T-a7ce061d-5a77-4654-a931-0a4f24aee192
Co-authored-by: Amp <amp@ampcode.com>
This commit is contained in:
249
internal/rpc/coverage_test.go
Normal file
249
internal/rpc/coverage_test.go
Normal file
@@ -0,0 +1,249 @@
|
||||
package rpc
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
"github.com/steveyegge/beads/internal/types"
|
||||
)
|
||||
|
||||
func TestSetTimeout(t *testing.T) {
|
||||
_, client, cleanup := setupTestServer(t)
|
||||
defer cleanup()
|
||||
defer client.Close()
|
||||
|
||||
client.SetTimeout(5 * time.Second)
|
||||
// No crash means success
|
||||
}
|
||||
|
||||
func TestShow(t *testing.T) {
|
||||
_, client, cleanup := setupTestServer(t)
|
||||
defer cleanup()
|
||||
defer client.Close()
|
||||
|
||||
// Create issue
|
||||
createArgs := &CreateArgs{
|
||||
Title: "Show Test",
|
||||
IssueType: "task",
|
||||
Priority: 1,
|
||||
}
|
||||
|
||||
createResp, err := client.Create(createArgs)
|
||||
if err != nil {
|
||||
t.Fatalf("Create failed: %v", err)
|
||||
}
|
||||
|
||||
var issue types.Issue
|
||||
if err := json.Unmarshal(createResp.Data, &issue); err != nil {
|
||||
t.Fatalf("Failed to unmarshal: %v", err)
|
||||
}
|
||||
|
||||
// Show issue
|
||||
showArgs := &ShowArgs{ID: issue.ID}
|
||||
resp, err := client.Show(showArgs)
|
||||
if err != nil {
|
||||
t.Fatalf("Show failed: %v", err)
|
||||
}
|
||||
|
||||
if !resp.Success {
|
||||
t.Errorf("Show failed: %s", resp.Error)
|
||||
}
|
||||
}
|
||||
|
||||
func TestReady(t *testing.T) {
|
||||
_, client, cleanup := setupTestServer(t)
|
||||
defer cleanup()
|
||||
defer client.Close()
|
||||
|
||||
args := &ReadyArgs{Limit: 10}
|
||||
resp, err := client.Ready(args)
|
||||
if err != nil {
|
||||
t.Fatalf("Ready failed: %v", err)
|
||||
}
|
||||
|
||||
if !resp.Success {
|
||||
t.Errorf("Ready failed: %s", resp.Error)
|
||||
}
|
||||
}
|
||||
|
||||
func TestStats(t *testing.T) {
|
||||
_, client, cleanup := setupTestServer(t)
|
||||
defer cleanup()
|
||||
defer client.Close()
|
||||
|
||||
resp, err := client.Stats()
|
||||
if err != nil {
|
||||
t.Fatalf("Stats failed: %v", err)
|
||||
}
|
||||
|
||||
if !resp.Success {
|
||||
t.Errorf("Stats failed: %s", resp.Error)
|
||||
}
|
||||
}
|
||||
|
||||
func TestAddDependency(t *testing.T) {
|
||||
_, client, cleanup := setupTestServer(t)
|
||||
defer cleanup()
|
||||
defer client.Close()
|
||||
|
||||
// Create two issues
|
||||
issue1, err := client.Create(&CreateArgs{Title: "Issue 1", IssueType: "task", Priority: 1})
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
var i1 types.Issue
|
||||
json.Unmarshal(issue1.Data, &i1)
|
||||
|
||||
issue2, err := client.Create(&CreateArgs{Title: "Issue 2", IssueType: "task", Priority: 1})
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
var i2 types.Issue
|
||||
json.Unmarshal(issue2.Data, &i2)
|
||||
|
||||
// Add dependency
|
||||
args := &DepAddArgs{FromID: i1.ID, ToID: i2.ID, DepType: "blocks"}
|
||||
resp, err := client.AddDependency(args)
|
||||
if err != nil {
|
||||
t.Fatalf("AddDependency failed: %v", err)
|
||||
}
|
||||
|
||||
if !resp.Success {
|
||||
t.Errorf("AddDependency failed: %s", resp.Error)
|
||||
}
|
||||
}
|
||||
|
||||
func TestRemoveDependency(t *testing.T) {
|
||||
_, client, cleanup := setupTestServer(t)
|
||||
defer cleanup()
|
||||
defer client.Close()
|
||||
|
||||
// Create issues and add dependency
|
||||
issue1, _ := client.Create(&CreateArgs{Title: "Issue 1", IssueType: "task", Priority: 1})
|
||||
var i1 types.Issue
|
||||
json.Unmarshal(issue1.Data, &i1)
|
||||
|
||||
issue2, _ := client.Create(&CreateArgs{Title: "Issue 2", IssueType: "task", Priority: 1})
|
||||
var i2 types.Issue
|
||||
json.Unmarshal(issue2.Data, &i2)
|
||||
|
||||
client.AddDependency(&DepAddArgs{FromID: i1.ID, ToID: i2.ID, DepType: "blocks"})
|
||||
|
||||
// Remove dependency
|
||||
args := &DepRemoveArgs{FromID: i1.ID, ToID: i2.ID}
|
||||
resp, err := client.RemoveDependency(args)
|
||||
if err != nil {
|
||||
t.Fatalf("RemoveDependency failed: %v", err)
|
||||
}
|
||||
|
||||
if !resp.Success {
|
||||
t.Errorf("RemoveDependency failed: %s", resp.Error)
|
||||
}
|
||||
}
|
||||
|
||||
func TestAddLabel(t *testing.T) {
|
||||
_, client, cleanup := setupTestServer(t)
|
||||
defer cleanup()
|
||||
defer client.Close()
|
||||
|
||||
// Create issue
|
||||
createResp, _ := client.Create(&CreateArgs{Title: "Label Test", IssueType: "task", Priority: 1})
|
||||
var issue types.Issue
|
||||
json.Unmarshal(createResp.Data, &issue)
|
||||
|
||||
// Add label
|
||||
args := &LabelAddArgs{ID: issue.ID, Label: "test"}
|
||||
resp, err := client.AddLabel(args)
|
||||
if err != nil {
|
||||
t.Fatalf("AddLabel failed: %v", err)
|
||||
}
|
||||
|
||||
if !resp.Success {
|
||||
t.Errorf("AddLabel failed: %s", resp.Error)
|
||||
}
|
||||
}
|
||||
|
||||
func TestRemoveLabel(t *testing.T) {
|
||||
_, client, cleanup := setupTestServer(t)
|
||||
defer cleanup()
|
||||
defer client.Close()
|
||||
|
||||
// Create issue with label
|
||||
createArgs := &CreateArgs{
|
||||
Title: "Label Test",
|
||||
IssueType: "task",
|
||||
Priority: 1,
|
||||
Labels: []string{"test"},
|
||||
}
|
||||
createResp, _ := client.Create(createArgs)
|
||||
var issue types.Issue
|
||||
json.Unmarshal(createResp.Data, &issue)
|
||||
|
||||
// Remove label
|
||||
args := &LabelRemoveArgs{ID: issue.ID, Label: "test"}
|
||||
resp, err := client.RemoveLabel(args)
|
||||
if err != nil {
|
||||
t.Fatalf("RemoveLabel failed: %v", err)
|
||||
}
|
||||
|
||||
if !resp.Success {
|
||||
t.Errorf("RemoveLabel failed: %s", resp.Error)
|
||||
}
|
||||
}
|
||||
|
||||
func TestBatch(t *testing.T) {
|
||||
_, client, cleanup := setupTestServer(t)
|
||||
defer cleanup()
|
||||
defer client.Close()
|
||||
|
||||
createArgs, _ := json.Marshal(CreateArgs{Title: "Batch 1", IssueType: "task", Priority: 1})
|
||||
args := &BatchArgs{
|
||||
Operations: []BatchOperation{
|
||||
{
|
||||
Operation: "create",
|
||||
Args: createArgs,
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
resp, err := client.Batch(args)
|
||||
if err != nil {
|
||||
t.Fatalf("Batch failed: %v", err)
|
||||
}
|
||||
|
||||
if !resp.Success {
|
||||
t.Errorf("Batch failed: %s", resp.Error)
|
||||
}
|
||||
}
|
||||
|
||||
func TestReposList(t *testing.T) {
|
||||
_, client, cleanup := setupTestServer(t)
|
||||
defer cleanup()
|
||||
defer client.Close()
|
||||
|
||||
resp, err := client.ReposList()
|
||||
if err != nil {
|
||||
t.Fatalf("ReposList failed: %v", err)
|
||||
}
|
||||
|
||||
if !resp.Success {
|
||||
t.Errorf("ReposList failed: %s", resp.Error)
|
||||
}
|
||||
}
|
||||
|
||||
func TestReposReady(t *testing.T) {
|
||||
_, client, cleanup := setupTestServer(t)
|
||||
defer cleanup()
|
||||
defer client.Close()
|
||||
|
||||
args := &ReposReadyArgs{}
|
||||
resp, err := client.ReposReady(args)
|
||||
if err != nil {
|
||||
t.Fatalf("ReposReady failed: %v", err)
|
||||
}
|
||||
|
||||
if !resp.Success {
|
||||
t.Errorf("ReposReady failed: %s", resp.Error)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user