Commit 7d060ec
Skip convenience method generation for multipart/mixed requests (#10967)
The C# emitter does not support `multipart/mixed` requests, yet since
the addition of `multipart/form-data` support it would emit an incorrect
convenience method for them. This disables convenience method generation
for multipart content types other than `multipart/form-data` and
surfaces a diagnostic instead.
The detection lives in the emitter so the generator simply honors the
resulting `generateConvenienceMethod` flag.
### Changes
- **`operation-converter.ts`**: In `fromSdkServiceMethodOperation`, when
an operation uses a `multipart/*` content type other than
`multipart/form-data`, `generateConvenienceMethod` is set to `false`
(protocol methods still emitted) and a warning diagnostic is reported. A
small `isUnsupportedMultipart` helper inspects the request media types.
- **`lib.ts`**: Added the `unsupported-multipart-convenience-method`
warning diagnostic.
- **Tests**: Added emitter unit tests in `operation-converter.test.ts` —
`multipart/mixed` turns off convenience method generation and emits the
warning, while `multipart/form-data` keeps convenience methods with no
diagnostic.
```ts
const requestMediaTypes = getRequestMediaTypes(method.operation);
if (generateConvenience && isUnsupportedMultipart(requestMediaTypes)) {
diagnostics.add(
createDiagnostic({
code: "unsupported-multipart-convenience-method",
format: { methodCrossLanguageDefinitionId: method.crossLanguageDefinitionId },
target: method.__raw ?? NoTarget,
}),
);
generateConvenience = false;
}
```
No existing test specs use `multipart/mixed`, so generated library
output is unchanged.
---------
Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com>
Co-authored-by: jorgerangel-msft <102122018+jorgerangel-msft@users.noreply.github.com>1 parent 3c918ef commit 7d060ec
3 files changed
Lines changed: 106 additions & 1 deletion
File tree
- packages/http-client-csharp/emitter
- src/lib
- test/Unit
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
95 | 95 | | |
96 | 96 | | |
97 | 97 | | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
98 | 104 | | |
99 | 105 | | |
100 | 106 | | |
| |||
Lines changed: 24 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
196 | 196 | | |
197 | 197 | | |
198 | 198 | | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
199 | 213 | | |
200 | 214 | | |
201 | 215 | | |
| |||
217 | 231 | | |
218 | 232 | | |
219 | 233 | | |
220 | | - | |
| 234 | + | |
221 | 235 | | |
222 | 236 | | |
223 | 237 | | |
| |||
751 | 765 | | |
752 | 766 | | |
753 | 767 | | |
| 768 | + | |
| 769 | + | |
| 770 | + | |
| 771 | + | |
| 772 | + | |
| 773 | + | |
| 774 | + | |
| 775 | + | |
| 776 | + | |
754 | 777 | | |
755 | 778 | | |
756 | 779 | | |
| |||
Lines changed: 76 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
622 | 622 | | |
623 | 623 | | |
624 | 624 | | |
| 625 | + | |
| 626 | + | |
| 627 | + | |
| 628 | + | |
| 629 | + | |
| 630 | + | |
| 631 | + | |
| 632 | + | |
| 633 | + | |
| 634 | + | |
| 635 | + | |
| 636 | + | |
| 637 | + | |
| 638 | + | |
| 639 | + | |
| 640 | + | |
| 641 | + | |
| 642 | + | |
| 643 | + | |
| 644 | + | |
| 645 | + | |
| 646 | + | |
| 647 | + | |
| 648 | + | |
| 649 | + | |
| 650 | + | |
| 651 | + | |
| 652 | + | |
| 653 | + | |
| 654 | + | |
| 655 | + | |
| 656 | + | |
| 657 | + | |
| 658 | + | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
| 662 | + | |
| 663 | + | |
| 664 | + | |
| 665 | + | |
| 666 | + | |
| 667 | + | |
| 668 | + | |
| 669 | + | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
| 677 | + | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
| 682 | + | |
| 683 | + | |
| 684 | + | |
| 685 | + | |
| 686 | + | |
| 687 | + | |
| 688 | + | |
| 689 | + | |
| 690 | + | |
| 691 | + | |
| 692 | + | |
| 693 | + | |
| 694 | + | |
| 695 | + | |
| 696 | + | |
| 697 | + | |
| 698 | + | |
| 699 | + | |
| 700 | + | |
0 commit comments