From fbc44d8f957e1f73a7ee014a8445f0fc8bf34585 Mon Sep 17 00:00:00 2001 From: beorn7 Date: Thu, 19 Mar 2015 19:28:21 +0100 Subject: [PATCH] Add benchmark for loading chunks and chunk descs. --- storage/local/fixtures/b0/04b821ca50ba26.db | Bin 0 -> 62460 bytes storage/local/fixtures/b0/37c21e884e4fc5.db | Bin 0 -> 48927 bytes storage/local/fixtures/b0/37de1e884e5469.db | Bin 0 -> 51009 bytes storage/local/persistence_test.go | 71 ++++++++++++++++++++ 4 files changed, 71 insertions(+) create mode 100644 storage/local/fixtures/b0/04b821ca50ba26.db create mode 100644 storage/local/fixtures/b0/37c21e884e4fc5.db create mode 100644 storage/local/fixtures/b0/37de1e884e5469.db diff --git a/storage/local/fixtures/b0/04b821ca50ba26.db b/storage/local/fixtures/b0/04b821ca50ba26.db new file mode 100644 index 0000000000000000000000000000000000000000..a9be8736432a15b8e92cad9e5451ceff7f745195 GIT binary patch literal 62460 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 literal 0 HcmV?d00001 diff --git a/storage/local/fixtures/b0/37de1e884e5469.db b/storage/local/fixtures/b0/37de1e884e5469.db new file mode 100644 index 0000000000000000000000000000000000000000..3445e010911beb8018c3f9e1adb801eb5abc62b6 GIT binary patch literal 51009 zcmeI5du)?c7{>c`7^(WA`XX;FocDH0ZNEEl*z>aGgCK2U?67GK^P3!BqS_| zamGj%MVWC%Fo6sN9A@euLdLy8GRH+gM5sb=T!hMPw&&gZo`z<%#ffRp!yoI@r|0|H zzUQ3Z`+Of^SQC0Jd2FO*v$a{XT|HipYvr)9>GOSmyhWZkC2aiM|Lj(E;gBJ6?7S$^ z|HWqxJZGT3oiz!3-{y34pC@p9;Fv)F-{^48+1!|L{7A-_{q_ z5(qxc+NpqWCC+l#*yK$g1O$FTwzi1I=3kOA;fO{;&{P*a+FDM8bLMcy$Oj8CSY8q# zM+J*;#)LR3#NoI0Qt*4VloR6f1iwXy!Qs3VVodORg>d9NBElIQV$7|*6#VYuh>$aj z6D(xRO~P6-i9oR7!Y&1bzvAo;8=EwEs*8cZ&znwCGsC47fxz~UUbsi-^X0c?$Uu3E zPy^J!pW0h`9W?Dr>!ZsAg7nY!=!C!~Z$t(HKM$wHV~lUsPy`ggztf^(B`73VDXRzs ziSza004qXTf3=O;K9TSScQph1%m#W`_-emsmLY+VcMT|!iW0lEh=hv zUG5d!=yFB${9czuUmJK)bYa>#(O1Tw6+LJ2Y0=(%kLcM8e-(YH^tk9*D~^i3xcac@ z{OSXu&+n)c{rZ6)L^qsri_X2YTlCphJ4L_NzE<>^Zd*man!H8y??b*5JuSUjv?p_u z=&92;iauHJrRd3vD@C7pf3@gI6<>%xzV36;6E|0gKDPH0(OE}67JcN*hoWD+S|&Xg5*xh^{Y*uI-g6`l&$~qPL}u6aB=5 zv7*19JWBNNnIlDSSvW%Uuy>ynU9)1i=%H&|qQ9*kEPC+HL87Y<3=sXer@!d0FZC5Y z@QyyBtJ?P#J>a39qBkb@5S=o#yXf`lPSO2d=qh^M^iHDt&PfnmxwwPqKFjVEy{4j_ zXy5j>x?~Xu@>_0< z&(UKa|0M&Pyj_BTz%OVVz=?|M#1@~Xrgeme7^#3&yP{qtgM##f>QVi*Bb&T@00fin zA@Hn&_R(=Ou%+fpA41A$Fb zfS{(jn15v~gs&bbf|*6I(l!wYoKvnUAau4{HZggla6(Ye@dFh=1!A=VmSZ}Bpeo_I zP6%w8k`VZN;=(iH3s00TX8u96Vw_dpnLsdl`wa~QHhH!=A@Fl-9Bdr_@`;(ffQ9Xw zN&-UaZUTX4uC1T{zjRZ-LXAzX6M%r5irD^Y!^AKH2?*{51cKt;b`1nJ0R&_r!~p+B ziD3@#CRaSLSvkoB0_WX#DIh%Jzp2Qk8so~l>A!NLBk>azKm}s10+u75Kv4Bf8=Vl? zWO(3`0hbJBbV*+ECMH7#H>-RzfnaoQTMYy@xjX;@fB+z<4HLuH4g`eMd;)>Td5;DH zn*f4|oq}f_-`$8?2Qu9R1oy)Pg5rJg8VGFiSR@1_1SAAA5<*TLfuQ4}`!o>P1Q5_A z&FYf8;!T`)N(iW+a5NfdqoIQ}=5iun8cT*eQ6{@!icz zN0bnfPZJ1^l_h8(u*pjU2>}TK3BinnP`jK!Q1J8v8VGCx29@Ic! zla~e(0ullef*A=RX%c~;KHjN;z$SozE@@VmMxjaY+NC-#>W+a5Fr38YUL62%6 Uun8cT*eQ6{@!iczM+$g<1Ej{ExBvhE literal 0 HcmV?d00001 diff --git a/storage/local/persistence_test.go b/storage/local/persistence_test.go index 2edc7d829b..d6b75d2ee0 100644 --- a/storage/local/persistence_test.go +++ b/storage/local/persistence_test.go @@ -884,3 +884,74 @@ func verifyIndexedState(i int, t *testing.T, b incrementalBatch, indexedFpsToMet } } } + +var fpStrings = []string{ + "b004b821ca50ba26", + "b037c21e884e4fc5", + "b037de1e884e5469", +} + +func BenchmarkLoadChunksSequentially(b *testing.B) { + p := persistence{ + basePath: "fixtures", + } + sequentialIndexes := make([]int, 47) + for i := range sequentialIndexes { + sequentialIndexes[i] = i + } + + var fp clientmodel.Fingerprint + for i := 0; i < b.N; i++ { + for _, s := range fpStrings { + fp.LoadFromString(s) + cds, err := p.loadChunks(fp, sequentialIndexes, 0) + if err != nil { + b.Error(err) + } + if len(cds) == 0 { + b.Error("could not read any chunks") + } + } + } +} + +func BenchmarkLoadChunksRandomly(b *testing.B) { + p := persistence{ + basePath: "fixtures", + } + randomIndexes := []int{1, 5, 6, 8, 11, 14, 18, 23, 29, 33, 42, 46} + + var fp clientmodel.Fingerprint + for i := 0; i < b.N; i++ { + for _, s := range fpStrings { + fp.LoadFromString(s) + cds, err := p.loadChunks(fp, randomIndexes, 0) + if err != nil { + b.Error(err) + } + if len(cds) == 0 { + b.Error("could not read any chunks") + } + } + } +} + +func BenchmarkLoadChunkDescs(b *testing.B) { + p := persistence{ + basePath: "fixtures", + } + + var fp clientmodel.Fingerprint + for i := 0; i < b.N; i++ { + for _, s := range fpStrings { + fp.LoadFromString(s) + cds, err := p.loadChunkDescs(fp, clientmodel.Latest) + if err != nil { + b.Error(err) + } + if len(cds) == 0 { + b.Error("could not read any chunk descs") + } + } + } +}