This commit is contained in:
Cassandra Heart 2024-02-21 02:10:23 -06:00 committed by GitHub
parent b681d489e9
commit 643823879b
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 110 additions and 42 deletions

View File

@ -886,11 +886,11 @@ func logoVersion(width int) string {
out += " ####################################### ########\n" out += " ####################################### ########\n"
out += " ############################# ##\n" out += " ############################# ##\n"
out += " \n" out += " \n"
out += " Quilibrium Node - v1.2.11 Dawn\n" out += " Quilibrium Node - v1.2.12 Dawn\n"
out += " \n" out += " \n"
out += " DB Console\n" out += " DB Console\n"
} else { } else {
out = "Quilibrium Node - v1.2.11 Dawn - DB Console\n" out = "Quilibrium Node - v1.2.12 Dawn - DB Console\n"
} }
return out return out
} }

View File

@ -59,5 +59,5 @@ func GetMinimumVersion() []byte {
} }
func GetVersion() []byte { func GetVersion() []byte {
return []byte{0x01, 0x02, 0x0B} return []byte{0x01, 0x02, 0x0C}
} }

View File

@ -280,6 +280,7 @@ func (d *DataTimeReel) runLoop() {
} }
d.addPending(selector, parent, distance, frame) d.addPending(selector, parent, distance, frame)
d.processPending(d.head, frame)
continue continue
} }
@ -293,24 +294,25 @@ func (d *DataTimeReel) runLoop() {
if frame.FrameNumber-d.head.FrameNumber != 1 || if frame.FrameNumber-d.head.FrameNumber != 1 ||
parent.Cmp(headSelector) != 0 { parent.Cmp(headSelector) != 0 {
d.logger.Debug( d.logger.Debug(
"frame has has gap or is non-descendent, add pending", "frame has has gap or is non-descendent, fork choice",
zap.Bool("has_gap", frame.FrameNumber-d.head.FrameNumber != 1), zap.Bool("has_gap", frame.FrameNumber-d.head.FrameNumber != 1),
zap.String("parent_selector", parent.Text(16)), zap.String("parent_selector", parent.Text(16)),
zap.String("head_selector", headSelector.Text(16)), zap.String("head_selector", headSelector.Text(16)),
) )
d.addPending(selector, parent, distance, frame) d.forkChoice(frame, distance)
d.processPending(d.head, frame)
continue continue
} }
// Otherwise set it as the next and process all pending // Otherwise set it as the next and process all pending
d.setHead(frame, distance) d.setHead(frame, distance)
d.processPending(d.head) d.processPending(d.head, frame)
} else if d.head.FrameNumber == frame.FrameNumber { } else if d.head.FrameNumber == frame.FrameNumber {
// frames are equivalent, no need to act // frames are equivalent, no need to act
if bytes.Equal(d.head.Output, frame.Output) { if bytes.Equal(d.head.Output, frame.Output) {
d.logger.Debug("equivalent frame") d.logger.Debug("equivalent frame")
d.processPending(d.head) d.processPending(d.head, frame)
continue continue
} }
@ -333,13 +335,13 @@ func (d *DataTimeReel) runLoop() {
) )
d.totalDistance.Sub(d.totalDistance, d.headDistance) d.totalDistance.Sub(d.totalDistance, d.headDistance)
d.setHead(frame, distance) d.setHead(frame, distance)
d.processPending(d.head) d.processPending(d.head, frame)
continue continue
} }
// Choose fork // Choose fork
d.forkChoice(frame, distance) d.forkChoice(frame, distance)
d.processPending(d.head) d.processPending(d.head, frame)
} else { } else {
d.logger.Debug("frame is lower height") d.logger.Debug("frame is lower height")
@ -371,7 +373,7 @@ func (d *DataTimeReel) runLoop() {
} }
d.addPending(selector, parent, distance, frame) d.addPending(selector, parent, distance, frame)
d.processPending(d.head) d.processPending(d.head, frame)
} }
} }
case <-d.done: case <-d.done:
@ -461,23 +463,34 @@ func (d *DataTimeReel) addPending(
func (d *DataTimeReel) processPending( func (d *DataTimeReel) processPending(
frame *protobufs.ClockFrame, frame *protobufs.ClockFrame,
lastReceived *protobufs.ClockFrame,
) { ) {
d.logger.Debug("process pending") d.logger.Debug(
"process pending",
zap.Int("pending_frame_numbers", len(d.pending)),
)
frameNumbers := []uint64{} frameNumbers := []uint64{}
for f := range d.pending { for f := range d.pending {
frameNumbers = append(frameNumbers, f) frameNumbers = append(frameNumbers, f)
d.logger.Debug(
"pending per frame number",
zap.Uint64("pending_frame_number", f),
zap.Int("pending_frames", len(d.pending[f])),
)
} }
sort.Slice(frameNumbers, func(i, j int) bool { sort.Slice(frameNumbers, func(i, j int) bool {
return frameNumbers[i] < frameNumbers[j] return frameNumbers[i] > frameNumbers[j]
}) })
limit := 8
lastSelector, err := lastReceived.GetSelector()
if err != nil {
panic(err)
}
for _, f := range frameNumbers { for _, f := range frameNumbers {
if f < d.head.FrameNumber { if f < d.head.FrameNumber {
delete(d.pending, f) delete(d.pending, f)
} }
if limit <= 0 {
return
}
nextPending := d.pending[f] nextPending := d.pending[f]
d.logger.Debug( d.logger.Debug(
@ -495,11 +508,17 @@ func (d *DataTimeReel) processPending(
continue continue
} }
// Pull the next // Pull the next
if nextPending != nil { for len(nextPending) != 0 {
d.logger.Debug("try process next") d.logger.Debug("try process next")
next := nextPending[0] next := nextPending[0]
d.pending[f] = d.pending[f] = d.pending[f][1:]
d.pending[f][1:] if f == lastReceived.FrameNumber && next.selector.Cmp(lastSelector) == 0 {
d.pending[f] = append(d.pending[f], next)
if len(d.pending[f]) == 1 {
nextPending = nil
}
continue
}
nextFrame, err := d.clockStore.GetParentDataClockFrame( nextFrame, err := d.clockStore.GetParentDataClockFrame(
d.filter, d.filter,
@ -510,17 +529,17 @@ func (d *DataTimeReel) processPending(
panic(err) panic(err)
} }
if nextFrame != nil { if nextFrame != nil {
d.pending[f] = append(d.pending[f], next)
d.logger.Debug("next found, send frame back in") d.logger.Debug("next found, send frame back in")
go func() { go func() {
d.frames <- nextFrame d.frames <- nextFrame
}() }()
limit-- return
} }
if len(d.pending[f]) == 0 { if len(d.pending[f]) == 0 {
d.logger.Debug("last next processing, clear list") d.logger.Debug("last next processing, clear list")
delete(d.pending, f) delete(d.pending, f)
nextPending = nil
} }
} }
} }
@ -642,16 +661,58 @@ func (d *DataTimeReel) forkChoice(
leftIndex := d.head leftIndex := d.head
rightIndex := frame rightIndex := frame
leftTotal := new(big.Int).Set(d.headDistance) leftTotal := new(big.Int).Set(d.headDistance)
overweight := big.NewInt(0)
rightTotal := new(big.Int).Set(distance) rightTotal := new(big.Int).Set(distance)
left := d.head.ParentSelector left := d.head.ParentSelector
right := frame.ParentSelector right := frame.ParentSelector
rightReplaySelectors := [][]byte{} rightReplaySelectors := [][]byte{}
for rightIndex.FrameNumber > leftIndex.FrameNumber {
rightReplaySelectors = append(
append(
[][]byte{},
right,
),
rightReplaySelectors...,
)
rightIndex, err = d.clockStore.GetParentDataClockFrame(
d.filter,
rightIndex.FrameNumber-1,
rightIndex.ParentSelector,
)
if err != nil {
// If lineage cannot be verified, set it for later
if errors.Is(err, store.ErrNotFound) {
d.addPending(selector, parentSelector, distance, frame)
return
} else {
panic(err)
}
}
right = rightIndex.ParentSelector
rightIndexDistance, err := d.GetDistance(rightIndex)
if err != nil {
panic(err)
}
// We accumulate right on left when right is longer because we cannot know
// where the left will lead and don't want it to disadvantage our comparison
overweight.Add(overweight, rightIndexDistance)
rightTotal.Add(rightTotal, rightIndexDistance)
}
// Walk backwards through the parents, until we find a matching parent // Walk backwards through the parents, until we find a matching parent
// selector: // selector:
for !bytes.Equal(left, right) { for !bytes.Equal(left, right) {
d.logger.Debug("scan backwards") d.logger.Debug(
"scan backwards",
zap.String("left_parent", hex.EncodeToString(leftIndex.ParentSelector)),
zap.String("right_parent", hex.EncodeToString(rightIndex.ParentSelector)),
)
rightReplaySelectors = append( rightReplaySelectors = append(
append( append(
@ -703,11 +764,13 @@ func (d *DataTimeReel) forkChoice(
frameNumber := rightIndex.FrameNumber frameNumber := rightIndex.FrameNumber
overweight.Add(overweight, leftTotal)
// Choose new fork based on lightest distance sub-tree // Choose new fork based on lightest distance sub-tree
if rightTotal.Cmp(leftTotal) > 0 { if rightTotal.Cmp(overweight) > 0 {
d.logger.Debug("proposed fork has greater distance", d.logger.Debug("proposed fork has greater distance",
zap.String("right_total", rightTotal.Text(16)), zap.String("right_total", rightTotal.Text(16)),
zap.String("left_total", leftTotal.Text(16)), zap.String("left_total", overweight.Text(16)),
) )
d.addPending(selector, parentSelector, distance, frame) d.addPending(selector, parentSelector, distance, frame)
return return

View File

@ -1,6 +1,7 @@
package time_test package time_test
import ( import (
"bytes"
"fmt" "fmt"
"strings" "strings"
"sync" "sync"
@ -213,9 +214,18 @@ func TestDataTimeReel(t *testing.T) {
datawg := sync.WaitGroup{} datawg := sync.WaitGroup{}
datawg.Add(1) datawg.Add(1)
dataFrameCh := d.NewFrameCh() dataFrameCh := d.NewFrameCh()
targetFrameParentSelector := []byte{}
go func() { go func() {
for i := 0; i < 41; i++ { for {
dataFrames = append(dataFrames, <-dataFrameCh) frame := <-dataFrameCh
dataFrames = append(dataFrames, frame)
if frame.FrameNumber == 40 && bytes.Equal(
frame.ParentSelector,
targetFrameParentSelector,
) {
break
}
} }
datawg.Done() datawg.Done()
}() }()
@ -377,6 +387,9 @@ func TestDataTimeReel(t *testing.T) {
10, 10,
) )
insertFrames = append(insertFrames, suppressedFrame) insertFrames = append(insertFrames, suppressedFrame)
if i == 39 {
targetFrameParentSelector = suppressedFrame.ParentSelector
}
frame, err = prover.ProveDataClockFrame( frame, err = prover.ProveDataClockFrame(
frame, frame,
[][]byte{}, [][]byte{},
@ -404,18 +417,10 @@ func TestDataTimeReel(t *testing.T) {
datawg.Wait() datawg.Wait()
for i := 0; i < 41; i++ { assert.Equal(t, uint64(40), dataFrames[len(dataFrames)-1].FrameNumber)
assert.NotNil(t, dataFrames[i]) assert.Equal(
t,
if i >= 40 { optimalKeySet[len(optimalKeySet)-1],
assert.Equal(t, uint64(i), dataFrames[i].FrameNumber) dataFrames[len(dataFrames)-1].GetPublicKeySignatureEd448().PublicKey.KeyValue,
assert.Equal( )
t,
optimalKeySet[i-31],
dataFrames[i].GetPublicKeySignatureEd448().PublicKey.KeyValue,
)
} else {
assert.Equal(t, uint64(i+1), dataFrames[i].FrameNumber)
}
}
} }

View File

@ -306,5 +306,5 @@ func printLogo() {
func printVersion() { func printVersion() {
fmt.Println(" ") fmt.Println(" ")
fmt.Println(" Quilibrium Node - v1.2.11 Dawn") fmt.Println(" Quilibrium Node - v1.2.12 Dawn")
} }

View File

@ -860,7 +860,7 @@ func (p *PebbleClockStore) GetParentDataClockFrame(
} else if err != nil && errors.Is(err, pebble.ErrNotFound) { } else if err != nil && errors.Is(err, pebble.ErrNotFound) {
data, closer, err = p.db.Get(clockDataFrameKey(filter, frameNumber)) data, closer, err = p.db.Get(clockDataFrameKey(filter, frameNumber))
if err != nil { if err != nil {
return nil, errors.Wrap(err, "get parent data clock frame") return nil, errors.Wrap(ErrNotFound, "get parent data clock frame")
} }
check = true check = true
} }