diff options
author | Felix Lange <fjl@twurst.com> | 2016-05-02 23:01:13 +0800 |
---|---|---|
committer | Felix Lange <fjl@twurst.com> | 2016-05-03 00:50:15 +0800 |
commit | 32bb280179a44b9ad1058766bf61cdbacea30a59 (patch) | |
tree | 7bf50a724703d5baf9423d891c229ea2936b5adf /p2p/server_test.go | |
parent | 1c20313a6a1a35d5f540f878e7c263327c2ccfc1 (diff) | |
download | go-tangerine-32bb280179a44b9ad1058766bf61cdbacea30a59.tar go-tangerine-32bb280179a44b9ad1058766bf61cdbacea30a59.tar.gz go-tangerine-32bb280179a44b9ad1058766bf61cdbacea30a59.tar.bz2 go-tangerine-32bb280179a44b9ad1058766bf61cdbacea30a59.tar.lz go-tangerine-32bb280179a44b9ad1058766bf61cdbacea30a59.tar.xz go-tangerine-32bb280179a44b9ad1058766bf61cdbacea30a59.tar.zst go-tangerine-32bb280179a44b9ad1058766bf61cdbacea30a59.zip |
p2p: improve readability of dial task scheduling code
Diffstat (limited to 'p2p/server_test.go')
-rw-r--r-- | p2p/server_test.go | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/p2p/server_test.go b/p2p/server_test.go index 02d1c8e01..b437ac367 100644 --- a/p2p/server_test.go +++ b/p2p/server_test.go @@ -235,6 +235,56 @@ func TestServerTaskScheduling(t *testing.T) { } } +// This test checks that Server doesn't drop tasks, +// even if newTasks returns more than the maximum number of tasks. +func TestServerManyTasks(t *testing.T) { + alltasks := make([]task, 300) + for i := range alltasks { + alltasks[i] = &testTask{index: i} + } + + var ( + srv = &Server{quit: make(chan struct{}), ntab: fakeTable{}, running: true} + done = make(chan *testTask) + start, end = 0, 0 + ) + defer srv.Stop() + srv.loopWG.Add(1) + go srv.run(taskgen{ + newFunc: func(running int, peers map[discover.NodeID]*Peer) []task { + start, end = end, end+maxActiveDialTasks+10 + if end > len(alltasks) { + end = len(alltasks) + } + return alltasks[start:end] + }, + doneFunc: func(tt task) { + done <- tt.(*testTask) + }, + }) + + doneset := make(map[int]bool) + timeout := time.After(2 * time.Second) + for len(doneset) < len(alltasks) { + select { + case tt := <-done: + if doneset[tt.index] { + t.Errorf("task %d got done more than once", tt.index) + } else { + doneset[tt.index] = true + } + case <-timeout: + t.Errorf("%d of %d tasks got done within 2s", len(doneset), len(alltasks)) + for i := 0; i < len(alltasks); i++ { + if !doneset[i] { + t.Logf("task %d not done", i) + } + } + return + } + } +} + type taskgen struct { newFunc func(running int, peers map[discover.NodeID]*Peer) []task doneFunc func(task) |