Commit 595afd6a authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent f30826a6
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
# See https://www.nexedi.com/licensing for rationale and options. # See https://www.nexedi.com/licensing for rationale and options.
"""Program treegen provides infrastructure to generate ZODB BTree states. """Program treegen provides infrastructure to generate ZODB BTree states.
It is used as helper for ΔBTree tests. It is used as helper for ΔBtail tests.
The following subcommands are provided: The following subcommands are provided:
......
...@@ -300,13 +300,13 @@ func (rbs RBucketSet) coverage() string { ...@@ -300,13 +300,13 @@ func (rbs RBucketSet) coverage() string {
return s return s
} }
// trackSet returns what should be ΔBtree.trackSet coverage for specified tracked key set. // trackSet returns what should be ΔBtail.trackSet coverage for specified tracked key set.
func (rbs RBucketSet) trackSet(tracked SetKey) PPTreeSubSet { func (rbs RBucketSet) trackSet(tracked SetKey) PPTreeSubSet {
trackSet, _ := rbs.trackSetWithCov(tracked) trackSet, _ := rbs.trackSetWithCov(tracked)
return trackSet return trackSet
} }
// trackSetWithCov returns what should be ΔBtree.trackSet and its key coverage for specified tracked key set. // trackSetWithCov returns what should be ΔBtail.trackSet and its key coverage for specified tracked key set.
func (rbs RBucketSet) trackSetWithCov(tracked SetKey) (trackSet PPTreeSubSet, keyCover *RangedKeySet) { func (rbs RBucketSet) trackSetWithCov(tracked SetKey) (trackSet PPTreeSubSet, keyCover *RangedKeySet) {
trackSet = PPTreeSubSet{} trackSet = PPTreeSubSet{}
keyCover = &RangedKeySet{} keyCover = &RangedKeySet{}
...@@ -1121,7 +1121,7 @@ func xverifyΔBTail_rebuild(t *testing.T, db *zodb.DB, treeRoot zodb.Oid, t0, t1 ...@@ -1121,7 +1121,7 @@ func xverifyΔBTail_rebuild(t *testing.T, db *zodb.DB, treeRoot zodb.Oid, t0, t1
}) })
} }
// xverifyΔBTail_rebuild_U verifies ΔBTree state after Update(ti->tj). // xverifyΔBTail_rebuild_U verifies ΔBtail state after Update(ti->tj).
func xverifyΔBTail_rebuild_U(t *testing.T, δbtail *ΔBtail, db *zodb.DB, treeRoot zodb.Oid, ti, tj *tTreeCommit, xat map[zodb.Tid]string, trackSet PPTreeSubSet, vδTok ...map[Key]Δstring) { func xverifyΔBTail_rebuild_U(t *testing.T, δbtail *ΔBtail, db *zodb.DB, treeRoot zodb.Oid, ti, tj *tTreeCommit, xat map[zodb.Tid]string, trackSet PPTreeSubSet, vδTok ...map[Key]Δstring) {
t.Helper() t.Helper()
X := exc.Raiseif X := exc.Raiseif
...@@ -1137,7 +1137,7 @@ func xverifyΔBTail_rebuild_U(t *testing.T, δbtail *ΔBtail, db *zodb.DB, treeR ...@@ -1137,7 +1137,7 @@ func xverifyΔBTail_rebuild_U(t *testing.T, δbtail *ΔBtail, db *zodb.DB, treeR
assertΔTtail(t, subj, δbtail, db, tj, treeRoot, xat, vδTok...) assertΔTtail(t, subj, δbtail, db, tj, treeRoot, xat, vδTok...)
} }
// xverifyΔBTail_rebuild_TR verifies ΔBTree state after Track(keys) + rebuild. // xverifyΔBTail_rebuild_TR verifies ΔBtail state after Track(keys) + rebuild.
func xverifyΔBTail_rebuild_TR(t *testing.T, db *zodb.DB, δbtail *ΔBtail, tj *tTreeCommit, treeRoot zodb.Oid, xat map[zodb.Tid]string, keys SetKey, trackSet PPTreeSubSet, trackNew, trackSetAfterRebuild PPTreeSubSet, vδTok ...map[Key]Δstring) { func xverifyΔBTail_rebuild_TR(t *testing.T, db *zodb.DB, δbtail *ΔBtail, tj *tTreeCommit, treeRoot zodb.Oid, xat map[zodb.Tid]string, keys SetKey, trackSet PPTreeSubSet, trackNew, trackSetAfterRebuild PPTreeSubSet, vδTok ...map[Key]Δstring) {
t.Helper() t.Helper()
X := exc.Raiseif X := exc.Raiseif
...@@ -1336,7 +1336,7 @@ func ΔBTest(xtest interface{}) ΔBTestEntry { ...@@ -1336,7 +1336,7 @@ func ΔBTest(xtest interface{}) ΔBTestEntry {
return test return test
} }
// ΔBCommit represent test commit changing a tree. // tTreeCommit represent test commit changing a tree.
type tTreeCommit struct { type tTreeCommit struct {
tree string // the tree in toplogy-encoding tree string // the tree in toplogy-encoding
prev *tTreeCommit // previous commit prev *tTreeCommit // previous commit
...@@ -1681,9 +1681,11 @@ func TestΔBTail(t *testing.T) { ...@@ -1681,9 +1681,11 @@ func TestΔBTail(t *testing.T) {
"T/B0:a", "T/B0:a",
// δtkeycov grows due to change in parent tree only // δtkeycov grows due to change in parent tree only
"T3/B1:a-B8:c",
"T7/B1:a-B8:c",
// ----//----
"T3/B1:a,2:b-B8:c,9:d", "T3/B1:a,2:b-B8:c,9:d",
"T7/B1:a,2:b-B8:c,9:d", "T7/B1:a,2:b-B8:c,9:d",
// ----//---- depth=2 // ----//---- depth=2
"T3/T-T/B1:a,2:b-B8:c,9:d", "T3/T-T/B1:a,2:b-B8:c,9:d",
"T7/T-T/B1:a,2:b-B8:c,9:d", "T7/T-T/B1:a,2:b-B8:c,9:d",
...@@ -1775,8 +1777,8 @@ func TestΔBTailAllStructs(t *testing.T) { ...@@ -1775,8 +1777,8 @@ func TestΔBTailAllStructs(t *testing.T) {
X := exc.Raiseif X := exc.Raiseif
// considerations: // considerations:
// - depth↑ better for testing (more tricky topologies) // - maxdepth↑ better for testing (more tricky topologies)
// - nsplit↑ not so better for testing (leave s=1, max s=2) // - maxsplit↑ not so better for testing (leave s=1, max s=2)
// - |kmin - kmax| affects N(variants) significantly // - |kmin - kmax| affects N(variants) significantly
// -> keep key range small (dumb increase does not help testing) // -> keep key range small (dumb increase does not help testing)
// - N(keys) affects N(variants) significantly // - N(keys) affects N(variants) significantly
...@@ -2006,39 +2008,6 @@ func allTestKeys(vt ...*tTreeCommit) SetKey { ...@@ -2006,39 +2008,6 @@ func allTestKeys(vt ...*tTreeCommit) SetKey {
return allKeys return allKeys
} }
/*
// easies debugging / makes error output stable from run to run.
func (ks SetKey) SortedElements() []Key {
keyv := ks.Elements()
sort.Slice(keyv, func(i, j int) bool {
return keyv[i] < keyv[j]
})
return keyv
}
func (ks SetKey) String() string {
strv := []string{}
for _, k := range ks.SortedElements() {
strv = append(strv, fmt.Sprintf("%d", k))
}
return "{" + strings.Join(strv, " ") + "}"
}
func (os SetOid) SortedElements() []zodb.Oid {
oidv := os.Elements()
sort.Slice(oidv, func(i, j int) bool {
return oidv[i] < oidv[j]
})
return oidv
}
func (os SetOid) String() string {
strv := []string{}
for _, oid := range os.SortedElements() {
strv = append(strv, fmt.Sprintf("%s", oid))
}
return "{" + strings.Join(strv, " ") + "}"
}
*/
func sortedKeys(kv map[Key]Δstring) []Key { func sortedKeys(kv map[Key]Δstring) []Key {
keyv := []Key{} keyv := []Key{}
for k := range kv { for k := range kv {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment