mattkrick/redux-optimistic-ui

Bug when attempting to commit / revert with invalid id

marcins opened this issue · 1 comments

I was working on improving the coverage reporting and noticed the cases dealing with an invalid transaction id aren't covered so was trying to write some tests for this, however I don't believe that the current behaviour when attempting to commit or revert with an invalid id is correct, because the invalid action gets pushed to the history and then "found".

Here's the scenario, using the INC/DEC reducer from tests:

  • Begin an INC transaction with id 0 => history: [ begin0 ]
  • Commit id 1 with type "--"
    • Line 131 will push the invalid "commit" action onto the history
    • Line 49 will find the invalid commit action and make it into an "empty" non-optimistic action

So the console error never gets triggered, and an additional, potentially invalid, action exists in history.

I haven't gone through the logic for a revert fully, but I believe a similar case exists - although in this case the delete on line 85 will cause the invalid item in the history to be deleted - but no console.error either since the invalid id will actually be found in the history.

My proposal: move the invalid id check against the history to Line 125 - throw an error rather than just console.error to stop execution.

Is my assessment correct? Are you happy with the solution? If so I'm happy to implement it.

I've gone ahead an pushed my proposed fix anyway, as #33 😄