-
Notifications
You must be signed in to change notification settings - Fork 26
Manual merge of curation data
Edits to studies result in a new commit on a "work in progress" branch of the phylesystem-#
repository.
The current automated merge rule is: Only merge the changes to the master branch if the study has not changed along the master branch since the parent of the new commit.
If this condition is not met, the curator will see a message such as:
Merge needed - Your changes were saved, but an edit by another user prevented your edit from merging to the publicly visible location. In the near future, we hope to take care of this automatically. In the meantime, please report this error to the Open Tree of Life software team
This can happen if the same curator has multiple tabs/windows/browser editing the same study, or if there are multiple curators editing the same study.
Basically, someone with ssh access needs to log on to api.opentreeoflife.org, and merge the content manually with git commands. The caveat is that, you don't want the phylesystem-api to be modifying the filesystem while you are in the midst of that operation. So, you need to set the lockfile that that the phylesystem-api uses.
Currently, you can do this most easily with 2 bash sessions.
$ ssh api
$ source venv/bin/activate
$ cd repo/phylesystem-1_par/phylesystem-1
$ python ~/repo/peyotl/extras/lock-phylesystem.py .
this last step will block, holding the file lock
$ ssh api
$ source venv/bin/activate
$ cd repo/phylesystem-1_par/phylesystem-1
$ git checkout NAME_OF_THE_UNMERGED_BRANCH_HERE
$ git merge master
VERIFY that there is no conflict
$ python ~/repo/peyotl/scripts/nexson/validate_ot_nexson.py study/pg_##/pg_####/pg_####.json
$ echo $? # to make sure that you get a 0 exit from the validate
$ git checkout master
$ git merge NAME_OF_THE_UNMERGED_BRANCH_HERE
Ctrl-D to end the lock-holding process