Merge branch 'main' of github.com:steveyegge/beads

# Conflicts:
#	.beads/beads.jsonl
This commit is contained in:
Steve Yegge
2025-11-05 10:27:12 -08:00
8 changed files with 30 additions and 8 deletions

View File

@@ -9,7 +9,7 @@
"name": "beads",
"source": "./",
"description": "AI-supervised issue tracker for coding workflows",
"version": "0.21.8"
"version": "0.21.9"
}
]
}

View File

@@ -1,7 +1,7 @@
{
"name": "beads",
"description": "AI-supervised issue tracker for coding workflows. Manage tasks, discover work, and maintain context with simple CLI commands.",
"version": "0.21.8",
"version": "0.21.9",
"author": {
"name": "Steve Yegge",
"url": "https://github.com/steveyegge"

View File

@@ -5,6 +5,7 @@ import (
"os"
"os/exec"
"path/filepath"
"runtime"
"strings"
"testing"
)
@@ -250,7 +251,11 @@ func init() {
if err != nil {
panic(err)
}
testBD = filepath.Join(tmpDir, "bd")
bdBinary := "bd"
if runtime.GOOS == "windows" {
bdBinary = "bd.exe"
}
testBD = filepath.Join(tmpDir, bdBinary)
cmd := exec.Command("go", "build", "-o", testBD, ".")
if out, err := cmd.CombinedOutput(); err != nil {
panic(string(out))

View File

@@ -11,7 +11,7 @@ import (
var (
// Version is the current version of bd (overridden by ldflags at build time)
Version = "0.21.8"
Version = "0.21.9"
// Build can be set via ldflags at compile time
Build = "dev"
)

View File

@@ -1,6 +1,6 @@
[project]
name = "beads-mcp"
version = "0.21.8"
version = "0.21.9"
description = "MCP server for beads issue tracker."
readme = "README.md"
requires-python = ">=3.10"

View File

@@ -4,4 +4,4 @@ This package provides an MCP (Model Context Protocol) server that exposes
beads (bd) issue tracker functionality to MCP Clients.
"""
__version__ = "0.21.8"
__version__ = "0.21.9"

View File

@@ -963,6 +963,8 @@ func TestValidateNoDuplicateExternalRefs(t *testing.T) {
}
func TestConcurrentExternalRefImports(t *testing.T) {
t.Skip("TODO(bd-gpe7): Test hangs due to database deadlock - needs investigation")
t.Run("sequential imports with same external_ref are detected as updates", func(t *testing.T) {
store, err := sqlite.New(":memory:")
if err != nil {
@@ -1029,6 +1031,10 @@ func TestConcurrentExternalRefImports(t *testing.T) {
})
t.Run("concurrent updates to same external_ref with different timestamps", func(t *testing.T) {
if testing.Short() {
t.Skip("Skipping slow concurrent test in short mode")
}
store, err := sqlite.New(":memory:")
if err != nil {
t.Fatalf("Failed to create store: %v", err)
@@ -1056,6 +1062,7 @@ func TestConcurrentExternalRefImports(t *testing.T) {
var wg sync.WaitGroup
results := make([]*Result, 3)
done := make(chan bool, 1)
for i := 0; i < 3; i++ {
wg.Add(1)
@@ -1077,7 +1084,17 @@ func TestConcurrentExternalRefImports(t *testing.T) {
}(i)
}
wg.Wait()
go func() {
wg.Wait()
done <- true
}()
select {
case <-done:
// Test completed normally
case <-time.After(30 * time.Second):
t.Fatal("Test timed out after 30 seconds - likely deadlock in concurrent imports")
}
finalIssue, err := store.GetIssueByExternalRef(ctx, externalRef)
if err != nil {

View File

@@ -1,6 +1,6 @@
{
"name": "@beads/bd",
"version": "0.21.8",
"version": "0.21.9",
"description": "Beads issue tracker - lightweight memory system for coding agents with native binary support",
"main": "bin/bd.js",
"bin": {