Skip to content
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

fix: plural drafts #163 #192

Open
wants to merge 4 commits into
base: main
Choose a base branch
from
Open

Conversation

geert-janklaps
Copy link

@geert-janklaps geert-janklaps commented Apr 4, 2024

Fixes #163

@daogrady
Copy link
Contributor

daogrady commented Apr 8, 2024

Hi @geert-janklaps,

thank you very much for taking on this issue! I have added a changelog entry and test cases for your contribution -- especially the latter are a bit prickly to write.
I will discuss this change with the runtime team later this day and if they don't object we can include this in the next release.
(FYI @johannes-vogel )

Best,
Daniel

@daogrady
Copy link
Contributor

daogrady commented Apr 8, 2024

Update on that: we still need to streamline how and where we want to allow the singular/ plural semantic, so I would like to postpone this PR until we have clarity on that.

@geert-janklaps
Copy link
Author

Hi @daogrady,

Sounds good to me! Do you have an idea when this could become part of the release / how long you'd postpone?
Currently I need to perform this change in the node modules folder manually for the handler registration to work (and not fail due to typing issues). This also means that for one of our solutions I'm unable to setup CI/CD pipelines for automated build and deployments. (nothing we can't handle, but it would make life easier for sure)

Cheers,
Geert-Jan

@johannes-vogel
Copy link

Hi @daogrady,

Sounds good to me! Do you have an idea when this could become part of the release / how long you'd postpone? Currently I need to perform this change in the node modules folder manually for the handler registration to work (and not fail due to typing issues). This also means that for one of our solutions I'm unable to setup CI/CD pipelines for automated build and deployments. (nothing we can't handle, but it would make life easier for sure)

Cheers, Geert-Jan

hi @geert-janklaps,

could you try registering an .after('each', ...) handler instead? See https://cap.cloud.sap/docs/node.js/core-services#srv-after-request

That might avoid fiddling in the node modules.

Copy link
Contributor

github-actions bot commented Jun 8, 2024

This PR has not been updated in a while. If it is still relevant, please comment on it to keep it open. The PR will be closed soon if it remains inactive.

@github-actions github-actions bot added the stale label Jun 8, 2024
@geert-janklaps
Copy link
Author

Hi @daogrady,

Any update on this one by any chance? (mainly commenting to prevent this from being closed automatically)

Cheers,
Geert-Jan

@github-actions github-actions bot removed the stale label Jun 9, 2024
@daogrady
Copy link
Contributor

Hi Geert-Jan,

sorry for the long silence on this one! The blocking issues have been resolved afaik, so I will bring this up again in the next cds-types meeting.

Best,
Daniel

P.S.: bummer I didn't run into you at recap 😕

@daogrady
Copy link
Contributor

daogrady commented Jul 5, 2024

Hi Geert-Jan,

I have not forgotten about this, but finding the right solution here is non-trivial. On the one hand, it would be correct to use a plural type for the .drafts on plural. On the other hand, it would mess with how types are derived in handler registrations, so you will probably get Array<Array<Singular>> in some cases. This needs some more thinking through, I believe. Sorry for the wait. :(

Best,
Daniel

@geert-janklaps
Copy link
Author

Hi Geert-Jan,

I have not forgotten about this, but finding the right solution here is non-trivial. On the one hand, it would be correct to use a plural type for the .drafts on plural. On the other hand, it would mess with how types are derived in handler registrations, so you will probably get Array<Array<Singular>> in some cases. This needs some more thinking through, I believe. Sorry for the wait. :(

Best, Daniel

Hi @daogrady,

No worries, in this case there are workarounds as suggested by Johannes above. I might be overlooking some cases (I'm looking at this from an implementation point of view), so definitely take your time to go through details so this doesn't create new bugs :)

Cheers,
Geert-Jan

Copy link
Contributor

This PR has not been updated in a while. If it is still relevant, please comment on it to keep it open. The PR will be closed soon if it remains inactive.

@github-actions github-actions bot added the stale label Sep 14, 2024
@daogrady
Copy link
Contributor

keep alive

@github-actions github-actions bot removed the stale label Sep 16, 2024
@stockbal
Copy link
Contributor

stockbal commented Oct 5, 2024

Hi @daogrady,

I enhanced the tests for CQL and service handler registration for plural drafts in my fork of @cap-js/cds-types. See cds-services.ts and cds-ql.ts.

I could find only one issue when registering the handler for after("READ", Foo.drafts, data => {}), but it was actually not because of the plural draft, but the singular one 😅, which infers the data parameter as a single object.
I explained this issue in the test case for cds-services.ts.

Please have a look when you have some time. From what I can see, nothing would stand in the way of making the switch of Plural.drafts from typeof Singular to typeof Plural.

Regards,
Ludwig

Copy link
Contributor

github-actions bot commented Dec 5, 2024

This PR has not been updated in a while. If it is still relevant, please comment on it to keep it open. The PR will be closed soon if it remains inactive.

@github-actions github-actions bot added the stale label Dec 5, 2024
@daogrady daogrady added keepalive Will not be closed by Stale bot and removed stale labels Dec 11, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
keepalive Will not be closed by Stale bot
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Plural.drafts could be typeof Plural
4 participants