Page MenuHomePhabricator

[Tunnelbroker] close RabbitMQ queue when client disconnects
ClosedPublic

Authored by kamil on Sep 28 2023, 7:42 AM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 16, 5:55 AM
Unknown Object (File)
Wed, Jan 15, 2:36 AM
Unknown Object (File)
Fri, Jan 10, 1:18 AM
Unknown Object (File)
Fri, Jan 10, 12:53 AM
Unknown Object (File)
Fri, Jan 10, 12:52 AM
Unknown Object (File)
Fri, Jan 10, 12:49 AM
Unknown Object (File)
Fri, Jan 10, 12:47 AM
Unknown Object (File)
Fri, Jan 10, 12:22 AM
Subscribers

Details

Summary

This might cause issues and was causing error in past:

  1. We run persistence test
  2. Queue is created, but never closed
  3. We run tests again, messages are in database, but are also put into RabbitMQ
  4. Consumer receives messages, and try to send but socket is closed at this time
  5. It generates error in Tunnelbroker logs

Depends on D9316

Test Plan
  1. Without this changes run:

cd services/commtest && cargo test --test tunnelbroker_persist_tests  -- --nocapture

  1. Wait for the test to finish
  2. Go to RabbitMQ console and it shows queues:

Screenshot 2023-09-28 at 15.28.20.png (236×1 px, 23 KB)

  1. Restart RabbitMQ
  2. Do steps 1, 2, 3 and the console should show 0 queues:

Screenshot 2023-09-28 at 15.40.04.png (248×1 px, 25 KB)

Diff Detail

Repository
rCOMM Comm
Lint
Lint Not Applicable
Unit
Tests Not Applicable