Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Migrate renterd subscriber to coreutils types #1098

Merged
merged 99 commits into from
May 14, 2024
Merged
Changes from 1 commit
Commits
Show all changes
99 commits
Select commit Hold shift + click to select a range
a1ba198
chain: introduce subscriber
peterjan Mar 25, 2024
d2fbe63
stores: add TestApplyChainUpdate
peterjan Mar 25, 2024
fb39286
bus: fix interface
peterjan Mar 25, 2024
a8560e5
testing: fix TestWalletTransactions
peterjan Mar 25, 2024
9358313
subscriber: commit update on close
peterjan Mar 25, 2024
8e91afd
test: fix TestUploadDownloadSpending
peterjan Mar 25, 2024
4735104
stores: update interface
peterjan Mar 26, 2024
0e80949
chain: update subscriber
peterjan Mar 26, 2024
c6a1898
testing: remove TODOs
peterjan Mar 26, 2024
de5402e
subscriber: get rid of OnReorg
peterjan Mar 27, 2024
0b012bc
subscriber: re-add OnReorg
peterjan Mar 27, 2024
452c39e
subscriber: get rid of sync interval entirely
peterjan Mar 27, 2024
ad998b4
chain: handle state elements
peterjan Mar 28, 2024
ba97b55
chain: get rid of update in favour of exposing a transaction from the…
peterjan Apr 5, 2024
1acaabd
stores: remove chain test
peterjan Apr 5, 2024
13d5415
worker: undo change
peterjan Apr 5, 2024
2a03ff4
debug: add logging
peterjan Apr 5, 2024
e341c92
Tmp commit
peterjan Apr 16, 2024
4fe7400
Merge branch 'its-happening' of github.com:SiaFoundation/renterd into…
peterjan Apr 16, 2024
b1065c1
Merge branch 'pj/default-db-logger' into pj/subscription-api
peterjan Apr 16, 2024
2174d81
node: change start order
peterjan Apr 16, 2024
b04ef80
subscriber: add waitgroup
peterjan Apr 16, 2024
0f88914
testing: fix TestBusRecordedMetrics
peterjan Apr 16, 2024
eb055f2
subscriber: check for close inside retry loop
peterjan Apr 16, 2024
22e93ea
testing: avoid NDF in TestWalletRedistribute
peterjan Apr 16, 2024
df62a81
node: sleep after closing listener
peterjan Apr 16, 2024
4b20878
testing: fix TestBusRecordedMetrics
peterjan Apr 16, 2024
d0518d3
stores: add rollback
peterjan Apr 16, 2024
c133e85
testing: add debug logger
peterjan Apr 17, 2024
37b4a8e
testing: configure MySQL
peterjan Apr 17, 2024
4571ceb
subscriber: update concurrency
peterjan Apr 17, 2024
1a88963
go.mod: update coreutils dep
peterjan Apr 17, 2024
bf0cf3b
testing: test for contracts length
peterjan Apr 17, 2024
0923817
subscriber: fix index
peterjan Apr 17, 2024
b87aa78
testing: fix TestBusRecordedMetrics NDF
peterjan Apr 17, 2024
a523bed
testing: add logging
peterjan Apr 17, 2024
21fe4ba
debug: add logging
peterjan Apr 17, 2024
f249ee8
node: pass WithPeerDiscoveryInterval
peterjan Apr 17, 2024
74e248f
node: add syncer opts to bus config
peterjan Apr 17, 2024
1427824
testing: lower ap heartbeat
peterjan Apr 17, 2024
bdeeb92
testing: add debug logger
peterjan Apr 17, 2024
8e77a8d
testing: default to debug logger
peterjan Apr 17, 2024
3bdfc80
testing: update TestBlocklist
peterjan Apr 17, 2024
a962725
subscriber: update way we handle rollbacks
peterjan Apr 17, 2024
38ee174
testing: trigger autopilot on failure
peterjan Apr 17, 2024
9ce29bb
testing: wait for peers
peterjan Apr 17, 2024
2168a00
internal: use shorter tx retry intervals in testing
peterjan Apr 17, 2024
88e8bd2
testing: fix TestBusRecordedMetrics
peterjan Apr 17, 2024
1a24d21
testing: fix TestNewTestCluster NDF
peterjan Apr 17, 2024
9627b67
debug: add logging
peterjan Apr 17, 2024
8880d6b
subscriber: add logging
peterjan Apr 18, 2024
029f1f5
Merge branch 'its-happening' of github.com:SiaFoundation/renterd into…
peterjan Apr 18, 2024
733bc31
testing: fix TestBusRecordedMetrics
peterjan Apr 18, 2024
310fbda
go.mod: upgrade coreutils dependency
peterjan Apr 18, 2024
5b47b7e
subscriber: add logging
peterjan Apr 18, 2024
fbd4c60
testing: retry stored data check
peterjan Apr 18, 2024
4af3312
testing: add micro sleep in MineBlocks
peterjan Apr 18, 2024
3cc5a9d
testing: update TestEphemeralAccounts
peterjan Apr 18, 2024
15adf40
stores: only update if revision number is smaller, fix NDF
peterjan Apr 18, 2024
4305ba2
stores: update contract
peterjan Apr 18, 2024
9820426
stores: improve perf in UpdateStateElements
peterjan Apr 19, 2024
8d52431
Merge branch 'its-happening' into pj/subscription-api
peterjan Apr 30, 2024
bfd11a6
stores: update ChainStore interface
peterjan Apr 30, 2024
f0cceb3
stores: remove height and block_id from wallet outputs
peterjan Apr 30, 2024
44613b2
ci: revert test.yml
peterjan Apr 30, 2024
c8cd78a
chain: rename manager.go to chain.go
peterjan Apr 30, 2024
c70c754
chain: make applyChainUpdate mirror revertChainUpdate
peterjan Apr 30, 2024
ecc005c
stores: fix UpdateStateElements performance
peterjan Apr 30, 2024
25c3ff1
ci: run test in loop and add logging
peterjan May 2, 2024
2a2198a
ci: fix test.yml
peterjan May 2, 2024
30b2611
stores: add logging
peterjan May 2, 2024
5379e82
stores: add logging to chainUpdateTx
peterjan May 2, 2024
2b7f6ba
subscriber: add debug logging
peterjan May 3, 2024
04b14f2
deps: update coreutils
peterjan May 3, 2024
2cc097c
stores: remove contract subscriber pattren
peterjan May 3, 2024
706c9d7
chain: avoid the error handling in ForEach
peterjan May 3, 2024
e189460
testing: use default logger in TestUnconfirmedContractArchival
peterjan May 3, 2024
8b22b75
testing: remove all NoOp loggers
peterjan May 3, 2024
094c962
testing: add TestContractExists
peterjan May 3, 2024
d189483
chain: add duration
peterjan May 3, 2024
0020c7a
testing: add context to sync issues
peterjan May 3, 2024
fe1fb70
autopilot: expose ContractConfirmationDeadline and use 144 in testing
peterjan May 3, 2024
8fc37a0
contractor: refresh contract metadata
peterjan May 3, 2024
85bf378
all: cleanup PR
peterjan May 3, 2024
893501e
Merge branch 'its-happening' of github.com:SiaFoundation/renterd into…
peterjan May 3, 2024
fae31b0
ci: tmp disable stores test
peterjan May 3, 2024
5532b8e
chain: update subscriber
peterjan May 3, 2024
7485ceb
stores: add logging
peterjan May 3, 2024
42ca8b2
stors: add logging
peterjan May 3, 2024
fbb6b5a
bus: fix store contract update, add sync height
peterjan May 3, 2024
5366be3
lint: disable builtinShadow
peterjan May 3, 2024
00ffb04
ci: re-enable store tests
peterjan May 3, 2024
9671cc0
test: block after mining
peterjan May 6, 2024
7c6d1a0
test: upgrade host
peterjan May 7, 2024
98940a7
Merge branch 'its-happening' of github.com:SiaFoundation/renterd into…
peterjan May 7, 2024
783f480
all: implement CR remarks
peterjan May 7, 2024
accc3a1
testing: always mine and sync
peterjan May 10, 2024
620c9f7
chain: fix chain.db location and pass genesis block id
peterjan May 10, 2024
4560593
bus: use maxSyncTime to decide whether the bus is synced or not
peterjan May 13, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
subscriber: update way we handle rollbacks
peterjan committed Apr 17, 2024

Verified

This commit was signed with the committer’s verified signature.
peterjan Peter-Jan Brone
commit a962725bfbbe90f3d2b9148712672e4fb35cc63a
23 changes: 16 additions & 7 deletions chain/subscriber.go
Original file line number Diff line number Diff line change
@@ -32,7 +32,7 @@ type (
}

ChainStore interface {
BeginChainUpdateTx() ChainUpdateTx
BeginChainUpdateTx() (ChainUpdateTx, error)
ChainIndex() (types.ChainIndex, error)
}

@@ -338,43 +338,52 @@ func (s *Subscriber) sync(index types.ChainIndex) error {
return nil
}

func (s *Subscriber) processUpdates(crus []chain.RevertUpdate, caus []chain.ApplyUpdate) (index types.ChainIndex, err error) {
start := time.Now()

func (s *Subscriber) processUpdates(crus []chain.RevertUpdate, caus []chain.ApplyUpdate) (index types.ChainIndex, _ error) {
// begin a new chain update
tx := s.cs.BeginChainUpdateTx()
tx, err := s.cs.BeginChainUpdateTx()
peterjan marked this conversation as resolved.
Show resolved Hide resolved
if err != nil {
return types.ChainIndex{}, fmt.Errorf("failed to begin chain update: %w", err)
}

// rollback on panic
defer func() {
fmt.Printf("DEBUG PJ: processUpdates took %v, err %v\n", time.Since(start), err)
if err != nil {
if r := recover(); r != nil {
tx.Rollback()
err = fmt.Errorf("processUpdates panic: %v", r)
return
}
}()

// process wallet updates
if err := wallet.UpdateChainState(tx, s.walletAddress, caus, crus); err != nil {
tx.Rollback()
return types.ChainIndex{}, err
}

// process revert updates
for _, cru := range crus {
if err := s.revertChainUpdate(tx, cru); err != nil {
tx.Rollback()
return types.ChainIndex{}, fmt.Errorf("failed to revert chain update: %w", err)
}
}

// process apply updates
if err := s.applyChainUpdates(tx, caus); err != nil {
tx.Rollback()
return types.ChainIndex{}, fmt.Errorf("failed to apply chain updates: %w", err)
}

// update chain index
index = caus[len(caus)-1].State.Index
if err := tx.UpdateChainIndex(index); err != nil {
tx.Rollback()
return types.ChainIndex{}, fmt.Errorf("failed to update chain index: %w", err)
}

// update failed contracts
if err := tx.UpdateFailedContracts(index.Height); err != nil {
tx.Rollback()
return types.ChainIndex{}, fmt.Errorf("failed to update failed contracts: %w", err)
}

8 changes: 6 additions & 2 deletions stores/chain.go
Original file line number Diff line number Diff line change
@@ -24,8 +24,12 @@ type chainUpdateTx struct {

// BeginChainUpdateTx starts a transaction and wraps it in a chainUpdateTx. This
// transaction will be used to process a chain update in the subscriber.
func (s *SQLStore) BeginChainUpdateTx() chain.ChainUpdateTx {
return &chainUpdateTx{tx: s.db.Begin()}
func (s *SQLStore) BeginChainUpdateTx() (chain.ChainUpdateTx, error) {
tx := s.db.Begin()
if tx.Error != nil {
return nil, tx.Error
}
return &chainUpdateTx{tx: tx}, nil
}

// ApplyIndex is called with the chain index that is being applied. Any
5 changes: 4 additions & 1 deletion stores/wallet.go
Original file line number Diff line number Diff line change
@@ -95,7 +95,10 @@ func (s *SQLStore) Tip() (types.ChainIndex, error) {
// SingleWalletStore interface which up until this point only had methods for
// querying the wallet.
func (s *SQLStore) UpdateChainState(reverted []chain.RevertUpdate, applied []chain.ApplyUpdate) error {
tx := s.BeginChainUpdateTx()
tx, err := s.BeginChainUpdateTx()
if err != nil {
return err
}
if err := wallet.UpdateChainState(tx, s.walletAddress, applied, reverted); err != nil {
tx.Rollback()
return err