1
0
mirror of https://github.com/AvengeMedia/DankMaterialShell.git synced 2026-01-24 21:42:51 -05:00

core: initialize fd pipes in tests and increase queue size in test

This commit is contained in:
bbedward
2026-01-02 22:30:42 -05:00
parent 7f10d6a9b8
commit ba2d51bcbb
2 changed files with 27 additions and 26 deletions

View File

@@ -13,7 +13,7 @@ import (
func TestManager_ActorSerializesOutputStateAccess(t *testing.T) { func TestManager_ActorSerializesOutputStateAccess(t *testing.T) {
m := &Manager{ m := &Manager{
cmdq: make(chan cmd, 128), cmdq: make(chan cmd, 8192),
stopChan: make(chan struct{}), stopChan: make(chan struct{}),
} }

View File

@@ -5,13 +5,29 @@ import (
"testing" "testing"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/assert"
"golang.org/x/sys/unix"
) )
func TestSharedContext_ConcurrentPostNonBlocking(t *testing.T) { func newTestSharedContext(t *testing.T, queueSize int) *SharedContext {
sc := &SharedContext{ t.Helper()
cmdQueue: make(chan func(), 256), fds := make([]int, 2)
stopChan: make(chan struct{}), if err := unix.Pipe(fds); err != nil {
t.Fatalf("failed to create test pipe: %v", err)
} }
t.Cleanup(func() {
unix.Close(fds[0])
unix.Close(fds[1])
})
return &SharedContext{
cmdQueue: make(chan func(), queueSize),
stopChan: make(chan struct{}),
wakeR: fds[0],
wakeW: fds[1],
}
}
func TestSharedContext_ConcurrentPostNonBlocking(t *testing.T) {
sc := newTestSharedContext(t, 256)
var wg sync.WaitGroup var wg sync.WaitGroup
const goroutines = 100 const goroutines = 100
@@ -33,10 +49,7 @@ func TestSharedContext_ConcurrentPostNonBlocking(t *testing.T) {
} }
func TestSharedContext_PostQueueFull(t *testing.T) { func TestSharedContext_PostQueueFull(t *testing.T) {
sc := &SharedContext{ sc := newTestSharedContext(t, 2)
cmdQueue: make(chan func(), 2),
stopChan: make(chan struct{}),
}
sc.Post(func() {}) sc.Post(func() {})
sc.Post(func() {}) sc.Post(func() {})
@@ -47,11 +60,8 @@ func TestSharedContext_PostQueueFull(t *testing.T) {
} }
func TestSharedContext_StartMultipleTimes(t *testing.T) { func TestSharedContext_StartMultipleTimes(t *testing.T) {
sc := &SharedContext{ sc := newTestSharedContext(t, 256)
cmdQueue: make(chan func(), 256), sc.started = true
stopChan: make(chan struct{}),
started: false,
}
var wg sync.WaitGroup var wg sync.WaitGroup
const goroutines = 10 const goroutines = 10
@@ -70,10 +80,7 @@ func TestSharedContext_StartMultipleTimes(t *testing.T) {
} }
func TestSharedContext_DrainCmdQueue(t *testing.T) { func TestSharedContext_DrainCmdQueue(t *testing.T) {
sc := &SharedContext{ sc := newTestSharedContext(t, 256)
cmdQueue: make(chan func(), 256),
stopChan: make(chan struct{}),
}
counter := 0 counter := 0
for i := 0; i < 10; i++ { for i := 0; i < 10; i++ {
@@ -89,10 +96,7 @@ func TestSharedContext_DrainCmdQueue(t *testing.T) {
} }
func TestSharedContext_DrainCmdQueueEmpty(t *testing.T) { func TestSharedContext_DrainCmdQueueEmpty(t *testing.T) {
sc := &SharedContext{ sc := newTestSharedContext(t, 256)
cmdQueue: make(chan func(), 256),
stopChan: make(chan struct{}),
}
sc.drainCmdQueue() sc.drainCmdQueue()
@@ -100,10 +104,7 @@ func TestSharedContext_DrainCmdQueueEmpty(t *testing.T) {
} }
func TestSharedContext_ConcurrentDrainAndPost(t *testing.T) { func TestSharedContext_ConcurrentDrainAndPost(t *testing.T) {
sc := &SharedContext{ sc := newTestSharedContext(t, 256)
cmdQueue: make(chan func(), 256),
stopChan: make(chan struct{}),
}
var wg sync.WaitGroup var wg sync.WaitGroup