-
Notifications
You must be signed in to change notification settings - Fork 504
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Test renamed imports #870
base: master
Are you sure you want to change the base?
Test renamed imports #870
Conversation
This PR is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 5 days |
Not stale |
This PR is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 5 days |
Not stale
…On Mon, Feb 15, 2021, 01:16 github-actions[bot] ***@***.***> wrote:
This PR is stale because it has been open 30 days with no activity. Remove
stale label or comment or this will be closed in 5 days
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#870 (comment)>, or
unsubscribe
<https://github.com/notifications/unsubscribe-auth/AEAHNIZM4GAKXJJXB4AQGTDS7BRWFANCNFSM4U3KRSUQ>
.
|
This PR is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 5 days |
Is there a plan to fix this? I think it fails because tsoa checks the name of the decorator. Instead of doing that, maybe the decorator should attach a metadata to the class or method. Then tsoa can check for the presence of the metadata instead of checking for the name of the decorator. This will make it easier to integrate tsoa to existing framework which also use decorators, as you can then compose decorators. For example, in the project I'm working on, I'm using inversify-express-utils, which allows dependencies to be injected into controller methods. But because this injected dependency will break tsoa, I have to make sure it's ignored with the class FoobarController {
@Post('/')
foobar(
// Looks ugly
@Inject() @Inject(TYPES.User) user: User,
@Body() req: FoobarRequest
) {
// ...
}
} If tsoa use the metadata approach, then I can create a custom decorator in my project that calls both of these decorators, so now it can look like this: class FoobarController {
@Post('/')
foobar(
// InjectUser() is wrapper for calling both @Inject() and @Inject(TYPES.User)
@InjectUser() user: User,
@Body() req: FoobarRequest
) {
// ...
}
} This will also fix the naming issue, as the user is now free to rename the decorators to anything when importing, as tsoa no longer depends on the name of the decorator. I'm not that familiar with tsoa codebase or it this would even work (so far I only made a small PR to add the |
This PR is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 5 days |
Not stale
…On Fri, Apr 30, 2021, 02:29 github-actions[bot] ***@***.***> wrote:
This PR is stale because it has been open 30 days with no activity. Remove
stale label or comment or this will be closed in 5 days
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#870 (comment)>, or
unsubscribe
<https://github.com/notifications/unsubscribe-auth/AEAHNI7CY6GAYGWSQUT3SUTTLH2WZANCNFSM4U3KRSUQ>
.
|
Probably not. At least I'm not aware of any easy solution.
We can do that to make the runtime work, but we can't access that metadata when we compile the Spec |
This PR is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 5 days |
No keep open option?
…On Sun, Jun 13, 2021, 02:28 github-actions[bot] ***@***.***> wrote:
This PR is stale because it has been open 30 days with no activity. Remove
stale label or comment or this will be closed in 5 days
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#870 (comment)>, or
unsubscribe
<https://github.com/notifications/unsubscribe-auth/AEAHNI6DO5EHC5TBRWB3RMLTSP3TXANCNFSM4U3KRSUQ>
.
|
The help wanted label should prevent that, I'll take a look and reopen manually if it happens again |
This is now partially solved (model renaming). As for Decorators, this is not really a prio for me. |
tsoa
does not support renaming of decorators in imports nor renaming of models. This is a problem in case there is a naming conflict, for example when you have a model namedPost
.The two new fixtures included in this PR contain examples of decorators such as
Get
being renamed and models being renamed.Model renaming crashes the test suite outright. Method decorator renaming fails more gracefully.