Skip to content

Conversation

@artemredkin
Copy link
Collaborator

@artemredkin artemredkin commented May 18, 2020

Fixes programming model for upload streaming

Motivation:
Right now EL on which we execute streaming call back is not explicitly defined. Also, we do not check on which EL part write is executed, meaning we can fail if .write is not called on correct EL.

Modifications:

  1. Call to body.stream is now executed on tasks EL
  2. Calls to writeAndFlush are always called on channel EL
  3. Added tests for those to cases
  4. Removed a hack in test introduced in test: that streaming actually works #219
  5. Fixed test: that streaming actually works #219 shutdown to not call to shutdown EL

Result:

  1. closes programming model: EventLoopPreference.delegate(on:) not respected for .stream #198
  2. closes StreamWriter expects to be called on some internal EventLoop #200

@artemredkin artemredkin marked this pull request as ready for review May 20, 2020 13:17
Copy link
Contributor

@weissi weissi left a comment

Choose a reason for hiding this comment

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

Thank you! LGTM!

@artemredkin artemredkin merged commit f81d0fe into swift-server:master May 20, 2020
@artemredkin artemredkin deleted the fix_streaming_el branch May 20, 2020 14:09
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.

StreamWriter expects to be called on some internal EventLoop programming model: EventLoopPreference.delegate(on:) not respected for .stream

2 participants