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

[Access] Make WebSocket responses from data providers consistent with Access REST API responses #6802

Merged

Conversation

UlyanaAndrukhiv
Copy link
Contributor

@UlyanaAndrukhiv UlyanaAndrukhiv commented Dec 12, 2024

Closes: #6775

Context

This pull request updates the WebSocket data providers to utilize the same models and response converters used by the Access REST API. By aligning the data processing logic, responses from WebSocket and REST API endpoints will now have consistent structure and content. Updated and added new unit tests to validate shared model usage.

@codecov-commenter
Copy link

codecov-commenter commented Dec 12, 2024

Codecov Report

Attention: Patch coverage is 51.53584% with 142 lines in your changes missing coverage. Please review.

Project coverage is 41.12%. Comparing base (6a7e0c7) to head (a7a4c00).

Files with missing lines Patch % Lines
...e/access/rest/common/models/mock/link_generator.go 14.37% 129 Missing and 2 partials ⚠️
engine/access/rest/router/router.go 0.00% 5 Missing ⚠️
engine/access/rest/http/routes/blocks.go 70.00% 3 Missing ⚠️
.../rest/websockets/data_providers/blocks_provider.go 80.00% 2 Missing and 1 partial ⚠️
Additional details and impacted files
@@           Coverage Diff            @@
##           master    #6802    +/-   ##
========================================
  Coverage   41.12%   41.12%            
========================================
  Files        2109     2116     +7     
  Lines      185513   185719   +206     
========================================
+ Hits        76286    76377    +91     
- Misses     102817   102931   +114     
- Partials     6410     6411     +1     
Flag Coverage Δ
unittests 41.12% <51.53%> (+<0.01%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

subscription.HandleResponse(p.send, func(b *flow.Block) (interface{}, error) {
var block commonmodels.Block

executionResult, err := p.getExecutionResult(b)
Copy link
Contributor

Choose a reason for hiding this comment

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

can you remind me why this is needed? I would expect the flow.Block object to already contain the correct execution results.

Copy link
Contributor Author

@UlyanaAndrukhiv UlyanaAndrukhiv Jan 2, 2025

Choose a reason for hiding this comment

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

I had a discussion with Yurii @durkmurder about execution results in flow.Block and the execution results from the flow.Block Payload cannot be used because they are not the execution result for this specific block.

Since the REST API block response is expected the execution result specific to this block, I retrieve it from storage by block ID.

Copy link
Contributor Author

@UlyanaAndrukhiv UlyanaAndrukhiv Jan 2, 2025

Choose a reason for hiding this comment

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

Discussion result:

  1. Remove of expand as an argument for Websockets block subscription.
  2. Do not include theexecution result into block response.
  3. Always return the payload in block response.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Copy link
Contributor

@Guitarheroua Guitarheroua left a comment

Choose a reason for hiding this comment

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

LGTM!

@UlyanaAndrukhiv UlyanaAndrukhiv requested a review from a team as a code owner January 13, 2025 08:47
@tarakby tarakby removed their request for review January 13, 2025 22:08
@peterargue peterargue added this pull request to the merge queue Jan 13, 2025
Merged via the queue into onflow:master with commit 23c5222 Jan 13, 2025
56 checks passed
@peterargue peterargue deleted the UlyanaAndrukhiv/6775-websocket-responses branch January 13, 2025 22:44
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Access] Make WebSocket responses from data providers consistent with Access REST API responses.
4 participants