Bug 174438

Summary: Add script to rebase patches during the WebKit2->WebKit/WebKit->WebKitLegacy transition
Product: WebKit Reporter: Jonathan Bedard <jbedard>
Component: Tools / TestsAssignee: Jonathan Bedard <jbedard>
Status: RESOLVED FIXED    
Severity: Normal CC: aakash_jain, dbates, lforschler, matthew_hanson, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Patch
none
Patch
none
Patch
none
Patch aakash_jain: review+

Jonathan Bedard
Reported 2017-07-12 15:54:45 PDT
We need a script to rebase patches during the WebKit2->WebKit/WebKit->WebKitLegacy transition.
Attachments
Patch (6.78 KB, patch)
2017-07-12 15:58 PDT, Jonathan Bedard
no flags
Patch (7.65 KB, patch)
2017-07-13 08:41 PDT, Jonathan Bedard
no flags
Patch (7.67 KB, patch)
2017-07-13 11:26 PDT, Jonathan Bedard
no flags
Patch (7.67 KB, patch)
2017-07-13 15:34 PDT, Jonathan Bedard
no flags
Patch (7.87 KB, patch)
2017-07-13 16:58 PDT, Jonathan Bedard
aakash_jain: review+
Radar WebKit Bug Importer
Comment 1 2017-07-12 15:55:17 PDT
Jonathan Bedard
Comment 2 2017-07-12 15:58:58 PDT
Matthew Hanson
Comment 3 2017-07-12 17:29:45 PDT
Comment on attachment 315296 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=315296&action=review Looks good to me pending successful tests cases for the most likely scenarios: 1. Patch that has not been rebased but touches WebKit (now WebKitLegacy) 2. Patch that has not been rebased but touches WebKit2 (now WebKit) 3. Patch that has not been rebased but touches both WebKit (now WebKitLegacy) and WebKIt2 (now WebKit) 4. Already rebased patch > Tools/Scripts/rebase-patch-after-webkit-move:35 > + Please include two lines between above function definitions. > Tools/Scripts/rebase-patch-after-webkit-move:44 > + I think that your approach is very clear. I have two comments: 1. Is the lack of space after '+++' intentional? The first two cases have trailing spaces. 2. Functional techniques provide an elegant solution for this type of problem if the scope is larger. This function could be written as: def is_editable_line(line): editable_prefixes = ('Index: ', '--- ', '+++') return any(map(line.startswith, editable_prefixes)) > Tools/Scripts/rebase-patch-after-webkit-move:52 > + return ALREADY_REBASED It would be good to call out that the `not in REBASE_DICTIONARY` check accounts for rebased paths that contain Source/WebKit (which could be either a source or a destination). Ditto for current paths below. > Tools/Scripts/rebase-patch-after-webkit-move:60 > + if os.path.join('Source', current_name) in line: The `os.path.join('Source, foo) in line` idiom is repeated a lot. I think a function would make it even easier to read. > Tools/Scripts/rebase-patch-after-webkit-move:81 > + I would like to see an isolated function parse the command line inputs / stdin and for this function to simply take the lines. Perhaps you could pass in a source keyword argument as well. > Tools/Scripts/rebase-patch-after-webkit-move:89 > + rebase_status = line_status You could rewrite this phrase as: rebase_status = max(rebase_status, line_status) > Tools/Scripts/rebase-patch-after-webkit-move:97 > + I'm tempted to suggest forcing input to stdin. That way you avoid situations like this where you are implicitly doing nothing for files. > Tools/Scripts/rebase-patch-after-webkit-move:100 > + Perhaps we could prompt instead of always rebasing? Or check for the existence of the existing paths? > Tools/Scripts/rebase-patch-after-webkit-move:110 > + I suggest embedding your top-level script in a block like this: if __name__ == '__main__': .... This prevents your script from running if it is ever imported as a module. That shouldn't happen here, but could easily happen if unit tests were ever added, for example. > Tools/Scripts/rebase-patch-after-webkit-move:124 > + exit(0) It's not necessary for this script, but you should look into the argparse module the next time you need to parse arguments from the command line. > Tools/Scripts/rebase-patch-after-webkit-move:126 > +if len(files_to_rebase) == 0: You can just write: if files_to_rebase:
Jonathan Bedard
Comment 4 2017-07-13 07:10:19 PDT
Comment on attachment 315296 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=315296&action=review >> Tools/Scripts/rebase-patch-after-webkit-move:81 >> + > > I would like to see an isolated function parse the command line inputs / stdin and for this function to simply take the lines. Perhaps you could pass in a source keyword argument as well. This is going to render your comment on line 97 moot. >> Tools/Scripts/rebase-patch-after-webkit-move:124 >> + exit(0) > > It's not necessary for this script, but you should look into the argparse module the next time you need to parse arguments from the command line. I'm aware of argparse. I figured that given the simplicity of this script, it was better to just manually parse them.
Jonathan Bedard
Comment 5 2017-07-13 07:19:28 PDT
(In reply to Matthew Hanson from comment #3) > Comment on attachment 315296 [details] > Patch I have comments on each of your 4 cases. > Looks good to me pending successful tests cases for the most likely > scenarios: > 1. Patch that has not been rebased but touches WebKit (now WebKitLegacy) This is the complicated case. In this instance, we can't tell if the patch has already been rebased (ie, those paths were originally WebKit2). As I mention in my response to #4, I like the idea of prompting the user, but that will only work for files. > 2. Patch that has not been rebased but touches WebKit2 (now WebKit) Definitely works. These patches will trigger the NEED_REBASE code path. > 3. Patch that has not been rebased but touches both WebKit (now > WebKitLegacy) and WebKIt2 (now WebKit) Definitely works. Like situation 2, this type of patch will trigger the NEED_REBASE code path. > 4. Already rebased patch If the patch contains WebKitLegacy, it will trigger the DO_NOT_NEED_REBASE path. This is the same path triggered by a patch which does not contain WebKit or WebKit2 in it. If, however, the patch only contains WebKit in it, we are in the same situation as #1. I think your suggestion to prompt is a good one, although, we can't prompt if the file was passed through stdin.
Jonathan Bedard
Comment 6 2017-07-13 08:41:05 PDT
Jonathan Bedard
Comment 7 2017-07-13 11:26:38 PDT
Jonathan Bedard
Comment 8 2017-07-13 11:27:00 PDT
Needed to add support for git-svn patches.
Jonathan Bedard
Comment 9 2017-07-13 15:34:46 PDT
Jonathan Bedard
Comment 10 2017-07-13 16:58:09 PDT
Jonathan Bedard
Comment 11 2017-07-13 17:20:13 PDT
Daniel Bates
Comment 12 2017-07-13 19:44:24 PDT
While I like the idea of behind this script historically we have used svn-apply to do such migrations.
Daniel Bates
Comment 13 2017-07-13 19:50:25 PDT
(In reply to Daniel Bates from comment #12) > While I like the idea of behind this script historically we have used > svn-apply to do such migrations. To elaborate further the reason we use svn-apply to do such migrations is because svn-apply familiar to those that use a SVN checkout of WebKit, is used by the EWS bots, commit queue, and webkit-patch. This has the benefit that patches posted to Bugzilla pre-migration can be migrated by the commit queue on landing among other benefits.
Jonathan Bedard
Comment 14 2017-07-14 08:09:29 PDT
(In reply to Daniel Bates from comment #13) > (In reply to Daniel Bates from comment #12) > > While I like the idea of behind this script historically we have used > > svn-apply to do such migrations. > > To elaborate further the reason we use svn-apply to do such migrations is > because svn-apply familiar to those that use a SVN checkout of WebKit, is > used by the EWS bots, commit queue, and webkit-patch. This has the benefit > that patches posted to Bugzilla pre-migration can be migrated by the commit > queue on landing among other benefits. I had considered using SVN apply to do this, but the trouble is, since this is a double move, it's very easy to construct a patch where the script cannot know if it has already been rebased. Any patch with a 'Source/WebKit/...' path in it may require a rebase, or it may not. Since we can't prompt the user on bots, I decided a temporary stand-alone script would be best in this case.
Note You need to log in before you can comment on or make changes to this bug.