Add the `rbt review` command.
Review Request #11883 — Created Nov. 24, 2021 and submitted
This change adds a new RBTools command for creating and editing reviews.
This uses the newMultiCommandsubclass in order to provide a variety
of functionality within a single command:
- rbt review editwill create or edit a draft review.
- rbt review discardwill discard a draft review.
- rbt review publishwill publish a draft review.
- rbt review add-diff-commentwill add a new diff comment.
- rbt review add-file-attachment-commentwill add a new file
 attachment comment.
- rbt review add-general-commentwill add a new general comment.
Based on work by Anahita Mohapatra at /r/11502/.
Ran through manual test cases for each of the review subcommands:
- Creating a new review with various content.
- Editing an existing draft review.
- Creating general comments (both markdown and plain)
- Creating file attachment comments (both markdown and plain)
- Creating diff comments (markdown and plain, single- and multi-line).
- Discarding a draft review.
- Publishing a draft review.
- Tested validation and error handling (file attachment IDs, diff
filenames, diff revisions)
| Summary | ID | 
|---|---|
| 73136b9fc5cee6ce3440b7e1dc973f2978b6a333 | 
| Description | From | Last Updated | 
|---|---|---|
| F401 'argparse' imported but unused |  reviewbot | |
| F401 'sys' imported but unused |  reviewbot | |
| F401 'six' imported but unused |  reviewbot | |
| F841 local variable 'file_attachment' is assigned to but never used |  reviewbot | |
| F841 local variable 'e' is assigned to but never used |  reviewbot | |
| rbt review <subcommand> --help? |  | |
| Can you add a Version Added? |  | |
| Can we give the base classes a Base prefix? |  | |
| Some of the commands do some lookups and possible CommandError raising before operating on a draft. If we do this … |  | |
| We shouldn't need to provide this. It'll be the default (and will use the correct string type). |  | |
| Typo: MARKDOMN -> MARKDOWN |  | |
| Can we end all the help_text strings with a period, like we do in Command.description and help= strings? Same applies … |  | |
| We use uppercase metavars in all options in the codebase. Can you update all the ones in the change to … |  | |
| This isn't needed. |  | |
| This should probably use default=1. I think we can then avoid checking against None below. |  | |
| Typo: "specifieud" |  | |
| We do self.options all over the place. Let's pull it out into a local variable, reduce the noise and the … |  | |
| "fid" is kind of confusing. Can we just make it "ID"? |  | |
| "id" -> "ID" I don't think we need the quotes around the ID numbers. We don't use them elsewhere. |  | |
| Missing a trailing period. |  | |
| Typo: MARKDOMN -> MARKDOWN. I state in another comment that we may want to consider a standard option we can … |  | |
| I was looking into whether we could avoid having to use two variables and the complex logic below but also … |  | |
| Missing a trailing period. |  | |
| We have this logic three times in two existing commands, and are adding more. While --markdown isn't a standard argument … |  | |
| The trailing newline isn't needed here. |  | |
| Missing a trailing period. |  | |
| Can we call this create_review_if_missing, and document it? |  | |
| This can use the new helper function, right? |  | 
- Commits:
- 
    Summary ID 7a15d3c64a6eb9c0da0bb9215310771a29513f3e 1c58b8cf688041a757331156a000d57efab3afa2 
Checks run (2 succeeded)
- 
 
- 
 
 
- 
 
 
- 
 
 
- 
 Some of the commands do some lookups and possible CommandErrorraising before operating on a draft. If we do this first, we can easily end up with empty drafts hanging around.How about just moving this to a get_review_draftmethod or something, and calling it when ready to work on the draft?
- 
 
 
- 
 
 
- 
 Can we end all the help_textstrings with a period, like we do inCommand.descriptionandhelp=strings?Same applies below. 
- 
 We use uppercase metavars in all options in the codebase. Can you update all the ones in the change to be uppercase? (Should also be one word: "FILENAME") 
- 
 
 
- 
 
 
- 
 
 
- 
 We do self.optionsall over the place. Let's pull it out into a local variable, reduce the noise and the repeated attribute lookups.Same with api_root.This applies to other implementations as well. 
- 
 
 
- 
 
 
- 
 
 
- 
 Typo: MARKDOMN->MARKDOWN.I state in another comment that we may want to consider a standard option we can plug in for Markdown, and given the error here, maybe this is a good time to do it? 
- 
 I was looking into whether we could avoid having to use two variables and the complex logic below but also gain the useful error message about mutual-exclusivity. argparse has an add_mutually_exclusive_groupfor this purpose, but it's probably too heavy-weight, and we don't have anOption/OptionGroupequivalent for it (though we could add it).Anyway, so I checked other commands, and this scenario is all over the place, and probably isn't a big deal. A --thingand--no-thingboth populating the same variable is common (such asrbt land --pushand--no-push), and we haven't heard of any confusion around them yet.So I think it'd be better to err on the side of simplicity here, have both these options use the same variable and default=None(which is the default value fordefaultanyway), and then trust the value when making decisions below.If we want to add mutual-exclusive support during parsing, we should probably handle that in common code somehow. 
- 
 
 
- 
 We have this logic three times in two existing commands, and are adding more. While --markdownisn't a standard argument (we should probably make a constant for it though), I think it'd be valuable to have at least a utility function that gives us a text type for a given value + capability, and just use that.
- 
 
 
- 
 
 
- Commits:
- 
    Summary ID 1c58b8cf688041a757331156a000d57efab3afa2 fc382004cfbd87825870de4a3c33f26eafd58230 
