Commit 2e26063
fix(generator): delegate RSC plugin helpers for cleanup re-render + harden specs
Address review findings on PR #3590 (native RSCRspackPlugin scaffolding).
The PR added `<%= rsc_plugin_class_name %>` / `<%= rsc_plugin_import_path %>`
to the managed serverWebpackConfig.js.tt and clientWebpackConfig.js.tt
templates. Those managed templates are re-rendered during stale-config
cleanup (`rendered_template_for_cleanup`) against the restricted
`TemplateRenderContext` binding, which did not expose those helpers. For any
RSC project the cleanup render raised NameError, printed a
"could not render template ... treating as non-removable" warning, and
wrongly preserved the managed config files. Delegate both helpers in
`TemplateRenderContext` (mirroring use_pro?/use_rsc?) to fix this, and add a
regression spec asserting the RSC managed templates render (not the
TEMPLATE_RENDER_FAILED sentinel) for both webpack and rspack projects.
Also:
- Make the rscWebpackConfig.js.tt skip comment bundler-neutral so
rspack-generated configs no longer reference RSCWebpackPlugin.
- Update two now-stale rsc_setup.rb docstrings that still described the
RSC plugin detection/injection as webpack-only after the regex was
broadened to match both plugin names.
- Add an rspack dedup/idempotency spec mirroring the existing webpack
contexts, exercising the rspack branch of RSC_PLUGIN_INVOCATION_REGEX
(verified to fail if the regex regresses to webpack-only).
Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>1 parent 5280682 commit 2e26063
5 files changed
Lines changed: 116 additions & 9 deletions
File tree
- react_on_rails
- lib/generators/react_on_rails
- templates/rsc/base/config/webpack
- spec/react_on_rails/generators
Lines changed: 11 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
109 | 109 | | |
110 | 110 | | |
111 | 111 | | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
112 | 120 | | |
113 | 121 | | |
114 | 122 | | |
| |||
963 | 971 | | |
964 | 972 | | |
965 | 973 | | |
966 | | - | |
967 | | - | |
| 974 | + | |
| 975 | + | |
| 976 | + | |
968 | 977 | | |
969 | 978 | | |
970 | 979 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
306 | 306 | | |
307 | 307 | | |
308 | 308 | | |
309 | | - | |
310 | | - | |
| 309 | + | |
| 310 | + | |
311 | 311 | | |
312 | 312 | | |
313 | 313 | | |
| |||
489 | 489 | | |
490 | 490 | | |
491 | 491 | | |
492 | | - | |
493 | | - | |
494 | | - | |
495 | | - | |
| 492 | + | |
| 493 | + | |
| 494 | + | |
| 495 | + | |
| 496 | + | |
496 | 497 | | |
497 | 498 | | |
498 | 499 | | |
| |||
Lines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
19 | 19 | | |
20 | 20 | | |
21 | 21 | | |
22 | | - | |
| 22 | + | |
23 | 23 | | |
24 | 24 | | |
25 | 25 | | |
| |||
Lines changed: 33 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
44 | 44 | | |
45 | 45 | | |
46 | 46 | | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
47 | 80 | | |
48 | 81 | | |
49 | 82 | | |
| |||
Lines changed: 64 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3657 | 3657 | | |
3658 | 3658 | | |
3659 | 3659 | | |
| 3660 | + | |
| 3661 | + | |
| 3662 | + | |
| 3663 | + | |
| 3664 | + | |
| 3665 | + | |
| 3666 | + | |
| 3667 | + | |
| 3668 | + | |
| 3669 | + | |
| 3670 | + | |
| 3671 | + | |
| 3672 | + | |
| 3673 | + | |
| 3674 | + | |
| 3675 | + | |
| 3676 | + | |
| 3677 | + | |
| 3678 | + | |
| 3679 | + | |
| 3680 | + | |
| 3681 | + | |
| 3682 | + | |
| 3683 | + | |
| 3684 | + | |
| 3685 | + | |
| 3686 | + | |
| 3687 | + | |
| 3688 | + | |
| 3689 | + | |
| 3690 | + | |
| 3691 | + | |
| 3692 | + | |
| 3693 | + | |
| 3694 | + | |
| 3695 | + | |
| 3696 | + | |
| 3697 | + | |
| 3698 | + | |
| 3699 | + | |
| 3700 | + | |
| 3701 | + | |
| 3702 | + | |
| 3703 | + | |
| 3704 | + | |
| 3705 | + | |
| 3706 | + | |
| 3707 | + | |
| 3708 | + | |
| 3709 | + | |
| 3710 | + | |
| 3711 | + | |
| 3712 | + | |
| 3713 | + | |
| 3714 | + | |
| 3715 | + | |
| 3716 | + | |
| 3717 | + | |
| 3718 | + | |
| 3719 | + | |
| 3720 | + | |
| 3721 | + | |
| 3722 | + | |
| 3723 | + | |
3660 | 3724 | | |
3661 | 3725 | | |
3662 | 3726 | | |
| |||
0 commit comments