- 
                Notifications
    You must be signed in to change notification settings 
- Fork 76
WIP: feat: handle concurrent updates to newly created record & upgrade deps #246
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
base: master
Are you sure you want to change the base?
Conversation
| I'm noticing that the test suite is somewhat broken. When I run  I think we should also consider upgrading the minimum supported node version in the next semver major release from 6 to 10 since 6 is already at "end-of-life" status and 8 will be within the next few months. This PR is going to need at least node 8.x because it uses  | 
126df6e    to
    e9f688f      
    Compare
  
    | Are you still creating an uuid() for new records? I'm not seeing you call your new function  And do you have a new test for the failing scenario? Without that it will be hard to really check the fix. And with just looking at the code I'm not entirely sure if the current promise setup will be correct. I believe that the id will only be set in ember-data after the createRecord promise is fulfilled. But your then on the promise we return to ember-data might be invoked before the chain that ember-data runs in their then really finishes. So ember-data might not be done with the first save() when your then is called for the second one. That is partly why I'm not really happy with ember-data just punting this issue to us. While I'm really impressed by your refactors and do appreciate it, I'm not really sure if refactoring and fixing a bug should be done in the same pull request. The refactor makes it harder to view any real changes. So maybe you can break them up into two separate pull request? | 
| 
 It's not my function. It's part of the Ember Data  
 
 For now I have been using the repro I linked in #239 and the associated commit in this PR does fix that. I can add a test to the suite here before we land this (haven't done it yet because what was in the suite already wasn't passing in all cases). 
 That's how it works if ember-data believes that the ID is being created on the server but not the case when  
 I'll be happy to cherry-pick things into separate PRs if you like. When I ran into trouble with the test suite (esp. when trying to update deps, etc.) I just started using this as my dev branch. 
 FYI you can filter the changes by commit (e.g. here's just the changes for the fix) | 
| 
 That seems very useful. Good catch. 
 With the id generation out of this part of the code, that might not be as needed, but could always help. 
 I did look at this commit separately, but I guess I didn't read your commit message explaining the generateIdForRecord there and I may just be affraid some changes might sneak in with other commits. But not completely trusting your commit cleanlyness might say more about my own commit quality than yours ;) Keep up the good work! | 
feaa442    to
    d98c091      
    Compare
  
    This commit changes how ember-pouch implements `Adapter.createRecord`, which is invoked after calling `.save()` on a new record, so that it does not create multiple records if `.save()` is called more than once before the first operation has finished. If `.save()` is only invoked once before the record has finished persisting to the DB (i.e. the promise that it returns has resolved) then the behavior is unchanged. However, subsequent calls will wait for the previously returned promise to resolve and then, if changes have been made to the record, it will delegate the task to `updateRecord`. To avoid a problem caused by ember-data changing the ID associated with the internalModel/record when the record has finished persisting, the `Adapter.generateIdForRecord` method has been implemented so that it is available immediately. Previously ember-pouch had still been generating this id during `createRecord`, but ember-data was not being made aware of this until its returned promise resolved. Finally, rather than rely on `adapter.db.rel.uuid()` to generate an RFC4122 v4 UUID (requiring initialization to have completed), this has been replaced by the equivalent `uuid` module from npm, and the ember-auto-import addon has been installed to make it easy to access this from within ember-pouch.
BREAKING CHANGE: drop support for NodeJS versions prior to 8.0.0
Some of the changes introduced while updating ember / ember-cli, resulted in test failures resembling the problem described at the URL below: emberjs/ember-qunit#309
The test labeled "creating an associated record stores a reference to it in the parent" was failing intermittently when run with other tests under conditions "dont save hasMany" and "sync". This problem appears to be caused by the test logic not waiting for `store.unloadAll()` to complete. The Ember Data API docs state that this function schedules its work to be done during the next run loop. However, instead of adding a delay and making assumptions about this, we wrap calls to this function in `run` to ensure that it has finished before continuing. See also: * https://api.emberjs.com/ember-data/3.14/classes/Store/methods/unloadAll?anchor=unloadAll * pouchdb-community#242 * pouchdb-community#243
| @broerse @jlami @backspace If you have a few minutes I would appreciate your feedback on this: 
 | 
| I was about to submit a PR myself for the  But if your way works, fine with me. I do have a preference for PRs to be separated more granularly. I think the test fix should be separate at least. Dropping Node 6 and 8 support is fine with me, but I think that would also belong in a separate PR. But I don’t know that we have any official policy on this, it’s just my own practice. I’ll have to look at your other two bullet points more closely later. | 
| 
 No problem, that's pretty common (esp. among projects that like to squash all the commits in a PR when merging). #247 makes minimal changes to expand test matrix and "get green" again. If you like, I can take a shot at applying the "multiple save" fix using the current UUID function so that it can be applied without updating node (so that we can use  | 
| FWIW, I've made a first pass at preventing document update conflicts due to concurrent updates by the same application instance. Need to clean-up and check tests but it seems to work, and you can view it here: https://github.com/jacobq/ember-pouch/tree/jrq-debug | 
This PR incorporates a number of changes (let me know if you'd rather I submit them separately):
Allows users to call
record.save()on a record which has not yet finished saving without causing an error or a duplicate record to be created in the database. (See commit notes.) (Closes Cannot call.save()multiple times #239)Fixes test suite race condition with
store.unloadAll(Closes Add logging that hints at relationship bug ≥ ED3.5 #243)Updates dependencies to current versions (dropping Node 6 support) and broadens test support matrix (Closes Add testing for LTS versions up to 3.8 #242)
Incorporates some minor refactoring (e.g. running some codemods for current ember conventions, replacing use of
varwithletandconst, replacing tabs with spaces, etc.)