aboutsummaryrefslogtreecommitdiffstats
path: root/miner/worker_test.go
diff options
context:
space:
mode:
authorgary rong <garyrong0905@gmail.com>2018-08-22 03:56:54 +0800
committerPéter Szilágyi <peterke@gmail.com>2018-08-22 03:56:54 +0800
commitb2c644ffb5c283a171ddf3889693673939917541 (patch)
tree501d3c337f5fb59404fd8d530eb247cdcc2144eb /miner/worker_test.go
parent522cfc68ff496aee4205add982db049dc3092024 (diff)
downloaddexon-b2c644ffb5c283a171ddf3889693673939917541.tar.gz
dexon-b2c644ffb5c283a171ddf3889693673939917541.tar.zst
dexon-b2c644ffb5c283a171ddf3889693673939917541.zip
cmd, eth, miner: make recommit configurable (#17444)
* cmd, eth, miner: make recommit configurable * cmd, eth, les, miner: polish a bit * miner: filter duplicate sealing work * cmd: remove uncessary conversion * miner: avoid microptimization in favor of cleaner code
Diffstat (limited to 'miner/worker_test.go')
-rw-r--r--miner/worker_test.go106
1 files changed, 104 insertions, 2 deletions
diff --git a/miner/worker_test.go b/miner/worker_test.go
index 34bb7f5f3..16708c18c 100644
--- a/miner/worker_test.go
+++ b/miner/worker_test.go
@@ -119,7 +119,7 @@ func (b *testWorkerBackend) PostChainEvents(events []interface{}) {
func newTestWorker(t *testing.T, chainConfig *params.ChainConfig, engine consensus.Engine) (*worker, *testWorkerBackend) {
backend := newTestWorkerBackend(t, chainConfig, engine)
backend.txPool.AddLocals(pendingTxs)
- w := newWorker(chainConfig, engine, backend, new(event.TypeMux))
+ w := newWorker(chainConfig, engine, backend, new(event.TypeMux), time.Second)
w.setEtherbase(testBankAddress)
return w, backend
}
@@ -327,7 +327,7 @@ func testRegenerateMiningBlock(t *testing.T, chainConfig *params.ChainConfig, en
}
}
b.txPool.AddLocals(newTxs)
- time.Sleep(3 * time.Second)
+ time.Sleep(time.Second)
select {
case <-taskCh:
@@ -335,3 +335,105 @@ func testRegenerateMiningBlock(t *testing.T, chainConfig *params.ChainConfig, en
t.Error("new task timeout")
}
}
+
+func TestAdjustIntervalEthash(t *testing.T) {
+ testAdjustInterval(t, ethashChainConfig, ethash.NewFaker())
+}
+
+func TestAdjustIntervalClique(t *testing.T) {
+ testAdjustInterval(t, cliqueChainConfig, clique.New(cliqueChainConfig.Clique, ethdb.NewMemDatabase()))
+}
+
+func testAdjustInterval(t *testing.T, chainConfig *params.ChainConfig, engine consensus.Engine) {
+ defer engine.Close()
+
+ w, _ := newTestWorker(t, chainConfig, engine)
+ defer w.close()
+
+ w.skipSealHook = func(task *task) bool {
+ return true
+ }
+ w.fullTaskHook = func() {
+ time.Sleep(100 * time.Millisecond)
+ }
+ var (
+ progress = make(chan struct{}, 10)
+ result = make([]float64, 0, 10)
+ index = 0
+ start = false
+ )
+ w.resubmitHook = func(minInterval time.Duration, recommitInterval time.Duration) {
+ // Short circuit if interval checking hasn't started.
+ if !start {
+ return
+ }
+ var wantMinInterval, wantRecommitInterval time.Duration
+
+ switch index {
+ case 0:
+ wantMinInterval, wantRecommitInterval = 3*time.Second, 3*time.Second
+ case 1:
+ origin := float64(3 * time.Second.Nanoseconds())
+ estimate := origin*(1-intervalAdjustRatio) + intervalAdjustRatio*(origin/0.8+intervalAdjustBias)
+ wantMinInterval, wantRecommitInterval = 3*time.Second, time.Duration(int(estimate))*time.Nanosecond
+ case 2:
+ estimate := result[index-1]
+ min := float64(3 * time.Second.Nanoseconds())
+ estimate = estimate*(1-intervalAdjustRatio) + intervalAdjustRatio*(min-intervalAdjustBias)
+ wantMinInterval, wantRecommitInterval = 3*time.Second, time.Duration(int(estimate))*time.Nanosecond
+ case 3:
+ wantMinInterval, wantRecommitInterval = time.Second, time.Second
+ }
+
+ // Check interval
+ if minInterval != wantMinInterval {
+ t.Errorf("resubmit min interval mismatch want %s has %s", wantMinInterval, minInterval)
+ }
+ if recommitInterval != wantRecommitInterval {
+ t.Errorf("resubmit interval mismatch want %s has %s", wantRecommitInterval, recommitInterval)
+ }
+ result = append(result, float64(recommitInterval.Nanoseconds()))
+ index += 1
+ progress <- struct{}{}
+ }
+ // Ensure worker has finished initialization
+ for {
+ b := w.pendingBlock()
+ if b != nil && b.NumberU64() == 1 {
+ break
+ }
+ }
+
+ w.start()
+
+ time.Sleep(time.Second)
+
+ start = true
+ w.setRecommitInterval(3 * time.Second)
+ select {
+ case <-progress:
+ case <-time.NewTimer(time.Second).C:
+ t.Error("interval reset timeout")
+ }
+
+ w.resubmitAdjustCh <- &intervalAdjust{inc: true, ratio: 0.8}
+ select {
+ case <-progress:
+ case <-time.NewTimer(time.Second).C:
+ t.Error("interval reset timeout")
+ }
+
+ w.resubmitAdjustCh <- &intervalAdjust{inc: false}
+ select {
+ case <-progress:
+ case <-time.NewTimer(time.Second).C:
+ t.Error("interval reset timeout")
+ }
+
+ w.setRecommitInterval(500 * time.Millisecond)
+ select {
+ case <-progress:
+ case <-time.NewTimer(time.Second).C:
+ t.Error("interval reset timeout")
+ }
+}