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

feat: toc and operation reply #523

Merged
merged 26 commits into from
Apr 18, 2024
Merged

Conversation

korifey91
Copy link
Contributor

Description

Notes:

  • Someone needs to take a look at the tests, as some previous test snapshots are incorrect.

If you are interested in this pull request, please guide me on how we can merge it.

Related issue(s)
Resolves #454, #452

Copy link

@github-actions github-actions bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Welcome to AsyncAPI. Thanks a lot for creating your first pull request. Please check out our contributors guide useful for opening a pull request.
Keep in mind there are also other channels you can use to interact with AsyncAPI community. For more details check out this issue.

@korifey91 korifey91 changed the title fix: TOC and operation reply fix: toc and operation reply Apr 1, 2024
@korifey91
Copy link
Contributor Author

/ptal

@asyncapi-bot
Copy link
Contributor

@fmvilas @derberg @magicmatatjahu Please take a look at this PR. Thanks! 👋

Copy link
Member

@derberg derberg left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@honnel @CodeGlitcher please join review at least as end users, not for code.

Just grab this PR and run generation locally with your files and share feedback

instead of usual @asyncapi/markdown-template you just need to put https://github.com/korifey91/async-api-markdown-template

test/helpers/common.test.js Show resolved Hide resolved
test/helpers/common.test.js Show resolved Hide resolved
@honnel
Copy link

honnel commented Apr 8, 2024

@honnel @CodeGlitcher please join review at least as end users, not for code.

Just grab this PR and run generation locally with your files and share feedback

instead of usual @asyncapi/markdown-template you just need to put https://github.com/korifey91/async-api-markdown-template

Generated TOC looks good to me, nice work! 🎉

@CodeGlitcher
Copy link

I rendered a preview of our asycn api documents and it looks good to us.
This would certainly help automate our api documentation in a readable format.

test/helpers/common.test.js Show resolved Hide resolved
Comment on lines 9 to 12
REQUEST: 'request',
SEND: 'publish',
REPLY: 'reply',
RECEIVE: 'subscribe',
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

v2 did not support request/reply pattern, so we really need to stick to publish/subscribe always, no request/reply

what I mean is that in case of v2 it is either publish or subscribe and I believe operation.reply() is anyway always undefined in v2

not sure if you are familiar in v2

so in v2 spec, we had publish/subscribe from perspective of the user of the API. So if AsyncAPI document for service A had publish operation - then it meant that end user can send a message, and service A in fact subscribes to a message. Same around, if service A had subscribe operation, it meant that user can subscribe so the service A was in fact publishing. Yeah, confusing, thus we changed it

in v3 we say what API does, so send means API sends and receive means API receives - as simple as that.

REQUEST: 'request' should be publish
REPLY: 'request' should be subscribe

any anyway, they will never be use as in v2, reply is always undefined

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for detailed comment! I appreciate it.
I'll fix types.

@derberg
Copy link
Member

derberg commented Apr 11, 2024

@korifey91 lemme know whenever you're ready for next review

@korifey91
Copy link
Contributor Author

@derberg I'm ready. Take a look, please

@derberg derberg changed the title fix: toc and operation reply feat: toc and operation reply Apr 11, 2024
@derberg
Copy link
Member

derberg commented Apr 11, 2024

@korifey91 I changed pr prefix to feat as we need to release it as minor not patch

please have a look into failing tests

@korifey91
Copy link
Contributor Author

@korifey91 I changed pr prefix to feat as we need to release it as minor not patch

please have a look into failing tests

We need someone we can trust to check the tests and ensure they are accurate. There are some issues with the snapshots that seem incorrect to me, as they do not contain the necessary information.

For example,

Operations component › for AsyncAPI v3 › should render reply operation

    expect(received).toMatchSnapshot()

    Snapshot name: `Operations component for AsyncAPI v3 should render reply operation 1`

    - Snapshot  -  1
    + Received  + 21

    @@ -40,6 +40,26 @@
      ```


      #### Response information

    - *  should be done to channel: `user/signedup`
    + * reply should be done to channel: `user/signedup`
    + #### Message `SomeReplyMessage`
    +
    + A longer description of the message
    +
    + ##### Payload
    +
    + | Name | Type | Description | Value | Constraints | Notes |
    + |---|---|---|---|---|---|
    + | (root) | object | - | - | - | **additional properties are allowed** |
    + | user | string | - | - | - | - |
    + | signup | number | - | - | - | - |
    +
    + > Examples of payload _(generated)_
    +
    + ```json
    + {
    +   "user": "string",
    +   "signup": 0
    + }
    + ```

As we can see here it expects one line of a text(which seems incorrect to me). There are fails with the same problems.

Except one, with a new CommonHelpers.isV3 method fail. There is a problem with a tested AsyncAPIDocument which doesn't have required version info(it is undefined there). But parser docs says that it can't be undefined.

@korifey91
Copy link
Contributor Author

@derberg If you trust me, I can override snapshots and fix the test with CommonHelpers.isV3 function in TableOfContents.test.js

@derberg
Copy link
Member

derberg commented Apr 11, 2024

yeah, they are human readable, so just update and push to PR and I will see what changed, no worries

Copy link

Quality Gate Passed Quality Gate passed

Issues
0 New issues
0 Accepted issues

Measures
0 Security Hotspots
No data about Coverage
No data about Duplication

See analysis details on SonarCloud

@korifey91
Copy link
Contributor Author

@derberg done, please take a look

@derberg
Copy link
Member

derberg commented Apr 11, 2024

LGTM! Thanks @korifey91 a 💯 if only all PR were on such good quality level!

@honnel @CodeGlitcher would it be a lot if I ask you again to test this PR 🙏🏼 there was some refactoring done after you had a look. Snapshots look good to me, but better double check 😄

Copy link
Member

@derberg derberg left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ok, looks like people do not have more feedback to share

thanks @korifey91 again

@derberg
Copy link
Member

derberg commented Apr 18, 2024

/rtm

@asyncapi-bot asyncapi-bot merged commit b709ff7 into asyncapi:master Apr 18, 2024
10 checks passed
@derberg
Copy link
Member

derberg commented Apr 18, 2024

@allcontributors please add @korifey91 for code,test

Copy link
Contributor

@derberg

I've put up a pull request to add @korifey91! 🎉

@derberg
Copy link
Member

derberg commented Apr 18, 2024

dependabot is such an ass..... pushed updates while release pipeline was in progress, and blocked release :(

@derberg
Copy link
Member

derberg commented Apr 18, 2024

@korifey91 maybe you would be willing to open another quick fix PR for #365 and then we would trigger release again

@korifey91
Copy link
Contributor Author

@korifey91 maybe you would be willing to open another quick fix PR for #365 and then we would trigger release again

I'll take a look and try to find some time for fix

@asyncapi-bot
Copy link
Contributor

🎉 This PR is included in version 1.6.0 🎉

The release is available on:

Your semantic-release bot 📦🚀

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Table of contents with AsyncAPIDocumentV3 no operations listed
5 participants