bench_test.go 857 Bytes
Newer Older
Brian Tiger Chow's avatar
Brian Tiger Chow committed
1 2 3
package decision

import (
4
	"fmt"
Brian Tiger Chow's avatar
Brian Tiger Chow committed
5 6 7
	"math"
	"testing"

8
	"github.com/ipfs/go-ipfs/exchange/bitswap/wantlist"
9 10 11 12
	u "gx/ipfs/QmPdKqUcHGFdeSpvjVoaTRPPstGif9GBZb5Q56RVw9o69A/go-ipfs-util"
	"gx/ipfs/QmPdxCaVp4jZ9RbxqZADvKH6kiCR5jHvdR5f2ycjAY6T2a/go-testutil"
	"gx/ipfs/QmVf8hTAsLLFtn4WPCRNdnaF2Eag2qTBS6uR8AiHPZARXy/go-libp2p-peer"
	cid "gx/ipfs/QmapdYm1b22Frv3k17fqrBYTFRxwiaVJkB299Mfn33edeB/go-cid"
Brian Tiger Chow's avatar
Brian Tiger Chow committed
13 14 15 16 17
)

// FWIW: At the time of this commit, including a timestamp in task increases
// time cost of Push by 3%.
func BenchmarkTaskQueuePush(b *testing.B) {
Brian Tiger Chow's avatar
Brian Tiger Chow committed
18
	q := newPRQ()
Brian Tiger Chow's avatar
Brian Tiger Chow committed
19 20 21 22 23
	peers := []peer.ID{
		testutil.RandPeerIDFatal(b),
		testutil.RandPeerIDFatal(b),
		testutil.RandPeerIDFatal(b),
	}
Brian Tiger Chow's avatar
Brian Tiger Chow committed
24
	b.ResetTimer()
Brian Tiger Chow's avatar
Brian Tiger Chow committed
25
	for i := 0; i < b.N; i++ {
26 27 28
		c := cid.NewCidV0(u.Hash([]byte(fmt.Sprint(i))))

		q.Push(&wantlist.Entry{Cid: c, Priority: math.MaxInt32}, peers[i%len(peers)])
Brian Tiger Chow's avatar
Brian Tiger Chow committed
29 30
	}
}