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

Make tests that after connected/clientReady event. #365

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

Conversation

gnought
Copy link
Collaborator

@gnought gnought commented Jan 24, 2020

We assumed that client connection is ready when writing mqtt packets, we strengthen tests not to have race conditions.

We assumed that client connection is ready when writing mqtt packets, we strengthen tests not to have race conditions.
@robertsLando
Copy link
Member

I think this depends on what we decide to do with #362

@gnought
Copy link
Collaborator Author

gnought commented Jan 24, 2020

@robertsLando Yes, it's inspired by #362

Copy link
Collaborator

@mcollina mcollina left a comment

Choose a reason for hiding this comment

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

I. would like to see some tests that verifies what happens when packets arrives before CONNACK is issued.

@robertsLando
Copy link
Member

@mcollina I have added those tests in my PR.

@robertsLando
Copy link
Member

Is this still required even if we have decided to queue incoming packets?

@robertsLando robertsLando requested a review from mcollina January 27, 2020 08:22
@mcollina
Copy link
Collaborator

I think we should wait to land #362

@robertsLando
Copy link
Member

@mcollina So what we do now with this now? Is it unecessary?

@mcollina
Copy link
Collaborator

This currently conflicts.

I'm not opposed to this landing.

@robertsLando
Copy link
Member

@mcollina CI fixed

@gnought
Copy link
Collaborator Author

gnought commented Jan 29, 2020

Please hold a bit, I’m going to make a big change. This PR may be closed after that if my work is successful.
Btw, I prefer to use rebase rather than merge

@robertsLando
Copy link
Member

@gnought 👍

@robertsLando
Copy link
Member

@gnought Any news about this?

@gnought
Copy link
Collaborator Author

gnought commented Feb 5, 2020

@robertsLando will keep you posted.
my upcoming changes will be

  • replace the packet queue before connected event
  • redesign the _nextBatch

@gnought
Copy link
Collaborator Author

gnought commented Feb 7, 2020

The upcoming changes have been ready in my local working copy.
I will submit a PR after the following PR has been merged into the main branch.
#409
#408
#416

The PR will be big, and simplify a lot.
After I submit the PR, this PR could be closed, and I will need all your help how to deal with the protocol decoder.

Copy link
Collaborator

@mcollina mcollina left a comment

Choose a reason for hiding this comment

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

lgtm

@gnought
Copy link
Collaborator Author

gnought commented Feb 10, 2020

@robertsLando Here is an early access (https://github.com/gnought/aedes/commits/next) what my next PR will be after migrating #408, #416 and #418 into the main branch.
The main changes are introducing a mqtt-stream-parser to replace the _nextBatch and _queue. However we still need a way to better work on the PROXY decoding.

@robertsLando
Copy link
Member

@gnought Did you made any performance testing?

@robertsLando
Copy link
Member

robertsLando commented Feb 11, 2020

How do you handle packets while client is connecting as you removed the queueLimit? I saw you have paused client in connect handle.

@robertsLando
Copy link
Member

robertsLando commented Feb 11, 2020

About PROXY decoding, the hook should be added here: https://github.com/gnought/aedes/blob/next/lib/mqtt-stream-parser.js#L19

Like we were doing in nextBatch before.

I also suggest to start adding some more comments to the code to make it more clear why we do some operations. Like I said for client pause, it could be difficult for new developers understand how the code works

@gnought
Copy link
Collaborator Author

gnought commented Feb 11, 2020

@robertsLando when we pause the stream, NodeJS will do buffering itself (https://nodejs.org/api/stream.html#stream_buffering), and we could still get those buffered data after resume. Constructing our own queue is a rewheel their work.

We could do some comments on coding side after we polish it. :)

@robertsLando
Copy link
Member

@gnought Interesting :) didn't know about that, and how could we handle an overflow so? Could we set a limit someway?

@robertsLando
Copy link
Member

robertsLando commented Feb 11, 2020

I answer to myself: highWaterMark option is used for that. Should this become an aedes option?

Does we handle case when stream write returns false ? (stream buffer limit is reached)

@getlarge
Copy link
Member

I the chunk content in the process function is the same as buf in nextBatch, like @robertsLando i also suppose it should take place before the parser.parse method.
@gnought have you tried your aedes branch behind a proxy yet ?

@robertsLando
Copy link
Member

@gnought What about your next branch? Would you mind to submit a pr?

@gnought
Copy link
Collaborator Author

gnought commented Feb 21, 2020

Will do. Let see if I can break it in a smaller pr. and how the PROXY architecture should be

@gnought
Copy link
Collaborator Author

gnought commented Feb 22, 2020

@ robertsLando What I understand is pipe() will do the overflow job in a smart way. https://github.com/nodejs/node/blob/1afec971304e5c6294bbf61bddb39b55e76b4672/lib/_stream_readable.js#L702-L720

@robertsLando
Copy link
Member

@gnought I don't understand, the link you pointed me doesn't seems to handle the overflow... We should handle it

@coveralls
Copy link

coveralls commented Jul 25, 2024

Pull Request Test Coverage Report for Build b7f7b1502cd22c78fe10692b561a683c6890122f-PR-365

Warning: This coverage report may be inaccurate.

This pull request's base commit is no longer the HEAD commit of its target branch. This means it includes changes from outside the original pull request, including, potentially, unrelated coverage changes.

Details

  • 0 of 0 changed or added relevant lines in 0 files are covered.
  • 3 unchanged lines in 1 file lost coverage.
  • Overall coverage decreased (-0.2%) to 95.526%

Files with Coverage Reduction New Missed Lines %
aedes.js 3 91.84%
Totals Coverage Status
Change from base Build 12725c607d30636383e29bd5292dfacf4236b02c: -0.2%
Covered Lines: 815
Relevant Lines: 838

💛 - Coveralls

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.

5 participants