github.com/yinchengtsinghua/golang-Eos-dpos-Ethereum@v0.0.0-20190121132951-92cc4225ed8e/p2p/discv5/topic_test.go (about) 1 2 //此源码被清华学神尹成大魔王专业翻译分析并修改 3 //尹成QQ77025077 4 //尹成微信18510341407 5 //尹成所在QQ群721929980 6 //尹成邮箱 yinc13@mails.tsinghua.edu.cn 7 //尹成毕业于清华大学,微软区块链领域全球最有价值专家 8 //https://mvp.microsoft.com/zh-cn/PublicProfile/4033620 9 //版权所有2016 Go Ethereum作者 10 //此文件是Go以太坊库的一部分。 11 // 12 //Go-Ethereum库是免费软件:您可以重新分发它和/或修改 13 //根据GNU发布的较低通用公共许可证的条款 14 //自由软件基金会,或者许可证的第3版,或者 15 //(由您选择)任何更高版本。 16 // 17 //Go以太坊图书馆的发行目的是希望它会有用, 18 //但没有任何保证;甚至没有 19 //适销性或特定用途的适用性。见 20 //GNU较低的通用公共许可证,了解更多详细信息。 21 // 22 //你应该收到一份GNU较低级别的公共许可证副本 23 //以及Go以太坊图书馆。如果没有,请参见<http://www.gnu.org/licenses/>。 24 25 package discv5 26 27 import ( 28 "encoding/binary" 29 "testing" 30 "time" 31 32 "github.com/ethereum/go-ethereum/common" 33 "github.com/ethereum/go-ethereum/common/mclock" 34 ) 35 36 func TestTopicRadius(t *testing.T) { 37 now := mclock.Now() 38 topic := Topic("qwerty") 39 rad := newTopicRadius(topic) 40 targetRad := (^uint64(0)) / 100 41 42 waitFn := func(addr common.Hash) time.Duration { 43 prefix := binary.BigEndian.Uint64(addr[0:8]) 44 dist := prefix ^ rad.topicHashPrefix 45 relDist := float64(dist) / float64(targetRad) 46 relTime := (1 - relDist/2) * 2 47 if relTime < 0 { 48 relTime = 0 49 } 50 return time.Duration(float64(targetWaitTime) * relTime) 51 } 52 53 bcnt := 0 54 cnt := 0 55 var sum float64 56 for cnt < 100 { 57 addr := rad.nextTarget(false).target 58 wait := waitFn(addr) 59 ticket := &ticket{ 60 topics: []Topic{topic}, 61 regTime: []mclock.AbsTime{mclock.AbsTime(wait)}, 62 node: &Node{nodeNetGuts: nodeNetGuts{sha: addr}}, 63 } 64 rad.adjustWithTicket(now, addr, ticketRef{ticket, 0}) 65 if rad.radius != maxRadius { 66 cnt++ 67 sum += float64(rad.radius) 68 } else { 69 bcnt++ 70 if bcnt > 500 { 71 t.Errorf("Radius did not converge in 500 iterations") 72 } 73 } 74 } 75 avgRel := sum / float64(cnt) / float64(targetRad) 76 if avgRel > 1.05 || avgRel < 0.95 { 77 t.Errorf("Average/target ratio is too far from 1 (%v)", avgRel) 78 } 79 }