Commit message should be generated from ChangeLog automatically. Currently, we need to write ChangeLog and commit messages. So, it requires writing it twice. And commit message is fragile: if we are working on local branch with multiple small changes, canonical commit message requires us to squash local commits for PR, which destroys the existing workflow (like https://bugs.webkit.org/show_bug.cgi?id=239327), which was working with webkit-patch. So, I think, at least, we should avoid writing the same things twice (ChangeLogs and commit message).
I have two ideas. 1. If we keep ChangeLogs, then I think `git webkit pr` should create PR-specific branch and generate commit messages from ChangeLogs automatically, so PR is always one commit, and we do not need to reflect our local branch's way (how many commits the local branch has etc.), and we can avoid writing the same ChangeLogs twice. 2. If we drop ChangeLogs soon, then I suggest adding COMMIT_MESSAGE file instead. It will not be landed in the tree. And locally, we can commit in our local development branch. And git webkit generates this file automatically as we do for ChangeLogs. We modify it for messages. git-webkit pr creates separate PR branch, which uses COMMIT_MESSAGE as a commit message and PR's issue message. But that branch also includes COMMIT_MESSAGE as a change. So reviewer can comment on commit log messages. And when merge-queue / git-webkit lands the change, it remove COMMIT_MESSAGE from the change, and use that content as a commit message.
(In reply to Yusuke Suzuki from comment #1) > 2. > If we drop ChangeLogs soon, then I suggest adding COMMIT_MESSAGE file > instead. It will not be landed in the tree. And locally, we can commit in > our local development branch. And git webkit generates this file > automatically as we do for ChangeLogs. > We modify it for messages. git-webkit pr creates separate PR branch, which > uses COMMIT_MESSAGE as a commit message and PR's issue message. But that > branch also includes COMMIT_MESSAGE as a change. So reviewer can comment on > commit log messages. > And when merge-queue / git-webkit lands the change, it remove COMMIT_MESSAGE > from the change, and use that content as a commit message. I think (2)'s way is how Gerrit etc. is doing. For example, https://chromium-review.googlesource.com/c/chromiumos/chromite/+/3586278 File "Commit message" is included in the change.
There is a 3rd option: get rid of ChangeLogs and exclusively rely on commit messages. I would prefer option #2, with a fallback to #3 if no COMMIT_MESSAGE is found. Note that Merge-Queue already modifies commits, and the difficulties of automatic squashing is all about commit messages, a COMMIT_MESSAGE file would fix that problem.
I think this is a release blocker level issue because various PRs are already failing to include ChangeLogs https://github.com/WebKit/WebKit/pull/291 https://github.com/WebKit/WebKit/pull/286. I think that this must be fixed before officially switching to GitHub. So far, it looks like 1-3 options work well, so some of them need to be implemented :)
I like option 3. I think that we should follow common GitHub workflows, even at the cost of regressing convenience in some cases. We shouldn't make it look like Gerrit or Subversion or anything else unless absolutely necessary (as it is with monotonically growing revision numbers).
(In reply to Alexey Proskuryakov from comment #5) > I like option 3. I think that we should follow common GitHub workflows, even > at the cost of regressing convenience in some cases. We shouldn't make it > look like Gerrit or Subversion or anything else unless absolutely necessary > (as it is with monotonically growing revision numbers). With option (3), how can we create multiple commits locally?
<rdar://problem/92084272>
This is no longer an issue now that we have dropped ChangeLogs.