Skip to content

Commit

Permalink
backport 5.1 reprocess do not fail on missing payload (#2246)
Browse files Browse the repository at this point in the history
* do not fail on missing payload (#2245)

* release notes
  • Loading branch information
gerardsn authored Jun 13, 2023
1 parent d8b2b9f commit c303cca
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 3 deletions.
10 changes: 10 additions & 0 deletions docs/pages/release_notes.rst
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,16 @@ Release notes

What has been changed, and how to update between versions.

************************
Hazelnut update (v5.1.2)
************************

Release date: 2023-06-13

- Fixed issue where a Reprocess failed due to missing data

**Full Changelog**: https://github.com/nuts-foundation/nuts-node/compare/v5.1.1...v5.1.2

************************
Hazelnut update (v5.1.1)
************************
Expand Down
6 changes: 3 additions & 3 deletions network/network.go
Original file line number Diff line number Diff line change
Expand Up @@ -760,8 +760,8 @@ func (n *Network) Reprocess(ctx context.Context, contentType string) (*Reprocess
// add to Nats
subject := fmt.Sprintf("%s.%s", events.ReprocessStream, contentType)
payload, err := n.state.ReadPayload(ctx, tx.PayloadHash())
if err != nil {
return nil, fmt.Errorf("reprocess abort on transaction %#x payload %#x: %w", tx.Ref(), tx.PayloadHash(), err)
if err != nil && !errors.Is(err, dag.ErrPayloadNotFound) {
return nil, fmt.Errorf("reprocess abort on transaction %s payload %s: %w", tx.Ref(), tx.PayloadHash(), err)
}
twp := events.TransactionWithPayload{
Transaction: tx,
Expand All @@ -774,7 +774,7 @@ func (n *Network) Reprocess(ctx context.Context, contentType string) (*Reprocess
Trace("Publishing transaction")
_, err = js.PublishAsync(subject, data)
if err != nil {
return nil, fmt.Errorf("reprocess abort on transaction %#x publish: %w", tx.Ref(), err)
return nil, fmt.Errorf("reprocess abort on transaction %s publish: %w", tx.Ref(), err)
}
}

Expand Down
19 changes: 19 additions & 0 deletions network/network_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -782,6 +782,25 @@ func TestNetwork_Reprocess(t *testing.T) {
assert.Equal(t, 0, counter)
})

t.Run("missing payload", func(t *testing.T) {
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
defer cancel()

setup, eventManager := newSetup(t)
setup.state.EXPECT().FindBetweenLC(gomock.Any(), uint32(0), uint32(1000)).Return([]dag.Transaction{tx}, nil)
setup.state.EXPECT().ReadPayload(gomock.Any(), tx.PayloadHash()).Return(nil, dag.ErrPayloadNotFound)
var counter int
wg := sync.WaitGroup{}
wg.Add(1)

subscribe(ctx, t, eventManager, &wg, &counter)

_, err := setup.network.Reprocess(ctx, "application/did+json")
require.NoError(t, err)
wg.Wait()
assert.Equal(t, 1, counter)
})

t.Run("error", func(t *testing.T) {
t.Run("query", func(t *testing.T) {
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
Expand Down

0 comments on commit c303cca

Please sign in to comment.