websockets-cli: a friendly companion for your web project

Kevin Tewouda
4 min readJul 18, 2022

A command line interface for websockets

An image of the illuminated globe
Photo by NASA on Unsplash

This blog post was originally published on dev.to

In this article, I will present the last open source project I have been working on for the last few months, websockets-cli. It is a Command Line Interface (CLI) to interact with a websocket server.

Why?

There are two main reasons for this project:

  • Each time I work on a web project involving websockets, I found myself wanting a simple CLI tool to test what I have coded. I always ended up writing a script to solve this issue because I could not find an appropriate library.
  • It is a fun project to do πŸ™ƒ

Of course, there are graphical solutions like Postman to help you with websockets, but I’m sure I’m not the only one who prefers to work with the terminal for such testing.

Installation

To install it, you will need python3.7 or newer and pip installed. After that, you can type:

$ pip install websockets-cli

You can also use another package manager like poetry. I have
a tutorial on it if you don’t know this tool.

$ poetry add -D websockets-cli

If you want some kind of global installation, you can use the pipx library.

$ pipx install websockets-cli

Settings

There are many settings you can configure for your needs. There are all defined in this section of the official documentation. You can configure them either using the:

  • pyproject.toml file
  • environment variables
  • a custom env file named .ws.env in your current working directory or home directory.

Note:

  • the pyproject.toml file has precedence over environment variables.

Usage

The CLI is straightforward to use. To know all available commands, just type ws in the terminal:

$ ws
Usage: ws [OPTIONS] COMMAND [ARGS]...

A convenient websocket cli.

Example usage:

# listens incoming messages from endpoint ws://localhost:8000/path
$ ws listen ws://localhost:8000/path

# sends text "hello world" in a text frame
$ ws text wss://ws.postman-echo.com/raw "hello world"

# sends the content from json file "hello.json" in a binary frame
$ ws byte wss://ws.postman-echo.com/raw file@hello.json

Options:
--version Show the version and exit.
-h, --help Show this message and exit.

Commands:
byte Sends binary message to URL endpoint.
echo-server Runs an echo websocket server.
install-completion Install completion script for bash, zsh and fish...
listen Listens messages on a given URL.
ping Pings a websocket server located at URL.
pong Sends a pong to websocket server located at URL.
session Opens an interactive session to communicate with...
tail An emulator of the tail unix command that output...
text Sends text message on URL endpoint.

Install-completion

The first command to use is install-completion which will add completion support for commands and options. It will work for bash, fish and zsh. Windows support (Powershell) is planned.

$ ws install-completion
# when the command succeeded, you should see the following message
Successfully installed completion script!

Echo-server

If you want to self-host an echo websocket server as Postman does, you can run the echo-server command. Here is an example:

$ ws echo-server -H ::1 -p 8000
Running server on ::1:8000 πŸ’«
# To stop the server, you can just tap Ctrl+C
^CProgram was interrupted by Ctrl+C, good bye! πŸ‘‹

Listen

Often, you will want to see incoming messages from a websocket endpoint. It is really easy with websockets-cli:

# assuming you have an endpoint localhost:8000 sending messages
$ ws listen :8000
# you will have an output like the following
──────────────────── TEXT message on 2022-05-25 07:10:07 ────────────────────────────────────
{"hello": "world"}
──────────────────── BINARY message on 2022-05-25 07:10:07 ──────────────────────────────────────
b'{"hello": "world"}'

Session

Probably the command you will use the most. It allows complete interaction with a websocket server. You can send ping, pong, close, text and binary frames.

$ ws session wss://ws.postman-echo.com/raw
Welcome to the interactive websocket session! 🌟
For more information about commands, type the help command.
When you see <> around a word, it means this argument is optional.
To know more about a particular command type help <command>.
To close the session, you can type Ctrl+D or the quit command.

> help
The session program lets you interact with a websocket endpoint with the
following commands:

β€’ ping <message>: Sends a ping with an optional message.
β€’ pong <message>: Sends a pong with an optional message.
β€’ text message: Sends text message.
β€’ byte message: Sends byte message.
β€’ close <code> <reason>: Closes the websocket connection with an optional code
and message.
β€’ quit: equivalent to close 1000.

> help close
Closes the session given a code and an optional reason.

Example usage:

If no code is given, 1000 is considered as default meaning a normal closure.
Thus, it is equivalent to the quit command.

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ > close β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Closes the connection with a code 1001 and no message.

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ > close 1001 β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
Closes the connection with a code 1003 and a message "received unknown data".

The message length must not be greater than 123 bytes.

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ > close 1003 'received unknown data' β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

To know more about close codes, please refer to the RFC.
> quit
Bye! πŸ‘‹

Thanks to prompt-toolkit, the session command has features like:

  • Syntax highlighting
  • Auto-completion of subcommands
  • Ability to read the history of the previous commands typed during the current session
  • Autosuggestion of commands based on your history within the current session

I will stop here for the presentation, if you want to know more about the project, you can read the official documentation.
I hope you will find it interesting to use if you play a lot with websockets. πŸ™‚

If you like my article and want to continue learning with me, don’t hesitate to follow me here and subscribe to my newsletter on substack πŸ˜‰

--

--

Kevin Tewouda

DΓ©serteur camerounais rΓ©sidant dΓ©sormais en France. PassionnΓ© de programmation, sport, de cinΓ©ma et mangas. J’écris en franΓ§ais et en anglais dΓ» Γ  mes origines.