eth/downloader: more context in errors (#21067)
This PR makes use of go 1.13 error handling, wrapping errors and using errors.Is to check a wrapped root-cause. It also removes the travis builders for go 1.11 and go 1.12.
This commit is contained in:
committed by
GitHub
parent
389da6aa48
commit
a5eee8d1dc
@ -242,27 +242,32 @@ func (dl *downloadTester) GetTd(hash common.Hash, number uint64) *big.Int {
|
||||
func (dl *downloadTester) InsertHeaderChain(headers []*types.Header, checkFreq int) (i int, err error) {
|
||||
dl.lock.Lock()
|
||||
defer dl.lock.Unlock()
|
||||
|
||||
// Do a quick check, as the blockchain.InsertHeaderChain doesn't insert anything in case of errors
|
||||
if _, ok := dl.ownHeaders[headers[0].ParentHash]; !ok {
|
||||
return 0, errors.New("unknown parent")
|
||||
return 0, errors.New("InsertHeaderChain: unknown parent at first position")
|
||||
}
|
||||
var hashes []common.Hash
|
||||
for i := 1; i < len(headers); i++ {
|
||||
hash := headers[i-1].Hash()
|
||||
if headers[i].ParentHash != headers[i-1].Hash() {
|
||||
return i, errors.New("unknown parent")
|
||||
return i, fmt.Errorf("non-contiguous import at position %d", i)
|
||||
}
|
||||
hashes = append(hashes, hash)
|
||||
}
|
||||
hashes = append(hashes, headers[len(headers)-1].Hash())
|
||||
// Do a full insert if pre-checks passed
|
||||
for i, header := range headers {
|
||||
if _, ok := dl.ownHeaders[header.Hash()]; ok {
|
||||
hash := hashes[i]
|
||||
if _, ok := dl.ownHeaders[hash]; ok {
|
||||
continue
|
||||
}
|
||||
if _, ok := dl.ownHeaders[header.ParentHash]; !ok {
|
||||
return i, errors.New("unknown parent")
|
||||
// This _should_ be impossible, due to precheck and induction
|
||||
return i, fmt.Errorf("InsertHeaderChain: unknown parent at position %d", i)
|
||||
}
|
||||
dl.ownHashes = append(dl.ownHashes, header.Hash())
|
||||
dl.ownHeaders[header.Hash()] = header
|
||||
dl.ownChainTd[header.Hash()] = new(big.Int).Add(dl.ownChainTd[header.ParentHash], header.Difficulty)
|
||||
dl.ownHashes = append(dl.ownHashes, hash)
|
||||
dl.ownHeaders[hash] = header
|
||||
dl.ownChainTd[hash] = new(big.Int).Add(dl.ownChainTd[header.ParentHash], header.Difficulty)
|
||||
}
|
||||
return len(headers), nil
|
||||
}
|
||||
@ -274,9 +279,9 @@ func (dl *downloadTester) InsertChain(blocks types.Blocks) (i int, err error) {
|
||||
|
||||
for i, block := range blocks {
|
||||
if parent, ok := dl.ownBlocks[block.ParentHash()]; !ok {
|
||||
return i, errors.New("unknown parent")
|
||||
return i, fmt.Errorf("InsertChain: unknown parent at position %d / %d", i, len(blocks))
|
||||
} else if _, err := dl.stateDb.Get(parent.Root().Bytes()); err != nil {
|
||||
return i, fmt.Errorf("unknown parent state %x: %v", parent.Root(), err)
|
||||
return i, fmt.Errorf("InsertChain: unknown parent state %x: %v", parent.Root(), err)
|
||||
}
|
||||
if _, ok := dl.ownHeaders[block.Hash()]; !ok {
|
||||
dl.ownHashes = append(dl.ownHashes, block.Hash())
|
||||
@ -301,7 +306,7 @@ func (dl *downloadTester) InsertReceiptChain(blocks types.Blocks, receipts []typ
|
||||
}
|
||||
if _, ok := dl.ancientBlocks[blocks[i].ParentHash()]; !ok {
|
||||
if _, ok := dl.ownBlocks[blocks[i].ParentHash()]; !ok {
|
||||
return i, errors.New("unknown parent")
|
||||
return i, errors.New("InsertReceiptChain: unknown parent")
|
||||
}
|
||||
}
|
||||
if blocks[i].NumberU64() <= ancientLimit {
|
||||
|
Reference in New Issue
Block a user