1 unstable release
0.1.0 | Aug 22, 2024 |
---|
#152 in WebSocket
8KB
89 lines
Rwst (Rust WebSocket Tester)
Rwst is a command-line tool designed to test WebSocket servers with ease. It allows you to connect to a WebSocket server, send messages, listen for incoming messages, and measure the time it takes for operations to complete. This tool is ideal for developers who need a quick and easy way to interact with and test WebSocket servers.
Features
- Connect: Establish a connection with a WebSocket server.
- Ping: Send a "Ping" message to the server and measure the round-trip time.
- Listen: Continuously listen for incoming messages from the server.
- Send: Send custom messages to the server and measure the time taken.
- Exit: Gracefully disconnect from the server.
Installation
- Ensure you have Rust and Cargo installed. If not, you can install it from rust-lang.org.
- Install via cargo:
cargo install rwst
Usage
To use Rwst, simply run the binary and provide the WebSocket server URL as an argument:
rwst ws://example.com:port
Once connected, you can choose from the following options:
- Ping: Sends a "Ping" message to the server and displays the time taken for the response.
- Listen: Listens for incoming messages from the server.
- Send: Prompts you to enter a custom message to send to the server.
- Exit: Disconnects from the server and exits the program.
Example
./rwst ws://echo.websocket.org
Example output:
Connecting to ws://echo.websocket.org...
Connection with ws://echo.websocket.org established successfully! Took 1.234s
Enter Command: Ping
Pong Took 0.002s
Enter Command: Send
Message: Hello, WebSocket!
Message sent: Hello, WebSocket! Took 0.001s
Enter Command: Listen
Message received: Hello, WebSocket!
Enter Command: Exit
Disconnecting from ws://echo.websocket.org
You chose to exit, bye 👋 see you later.
Dependencies
- Clap: Command-line argument parsing.
- Colored: Terminal text coloring.
- Tungstenite: WebSocket client library.
- Inquire: Interactive prompts for command-line interfaces.
Contributing
Contributions are welcome! Please fork the repository and submit a pull request with your changes.
License
This project is licensed under the MIT License. See the LICENSE file for more details.
Dependencies
~5–17MB
~156K SLoC