A simple command line tool for testing and moving servos
This project has been archived.
The maintainers of this project have marked this project as archived. No new releases are expected.
Project description
Servotester
Just another program to test servos if they work
This Project is a multi purpose diognostic tool for testing sts3215 servos (also standard pwm servos [i think]). I needed a way to bench mark my servos for my other projects to test if they even work.
YOU WILL NEED
STS3215 servos (obviously) Wonrabai/Waveshare bus servo Adapter (A): (Jumper set to Mode B) like this one https://www.amazon.com/Waveshare-Integrates-Control-Circuit-Supports/dp/B0CTMM4LWK/ (now optional! just enter test mode)
- USB-C cable
- 12V power supply (for the servo)
Safety: The servos are quite storong so please remove any obstructions and it has safety features like overcurrent protection and overtemperature protection BUT it can still break if you abuse it enough. Guardrails: Integrated error handling for disconnected hardware or serial collisions.
Installation
Installation
pip install servo_tester
servotest
Update the PORT variable in main.py to match your Device Manager (e.g., COM3 or /dev/ttyUSB0).
Configuration
Open Servo_Benchmark_tester.py in your text editor and check the top of the script:
-
Hardware Mode: Change PORT to match your Device Manager (e.g., COM3 on Windows or /dev/ttyUSB0 on Linux).
-
Test Mode: Change PORT to "TEST". This lets you run the script without any hardware connected. It will skip the serial check and print the raw hex packets to your screen in BRIGHT RED so you can verify the math and logic.
Select Your Mode
Run the script
-
Option [1] Automatic Benchmark: The script performs a "sanity check" sequence. It tests the absolute minimum (0), the absolute maximum (4095), and runs a "sweep-swoop" rapid response test before returning the servo to neutral.
-
Option [2] Live/Manual Mode: * Raw: Type a number between 0-4095 to move to a specific register position.
Degrees: Type a number followed by d (e.g., 180d or 90.5d) to move to a specific angle.
Exit: Type exit to return to the main menu.
-
[3] Macro mode: it will copy all the instrucitons made in the live mode and replay them in the same order.
-
[4] Clear Macro & Reset: it will clear all the instrucitons made in the live mode and replay them in the same order.
TROUBLESHOOTING
If you see a [GUARDRAIL] ERROR, check the following common issues:
-
Power: Is the 12V Power Supply actually plugged into the Driver Board? (USB alone won't move the servos).
-
Jumper: Is the jumper on the Waveshare board set to Mode B (USB Mode)?
-
Port Busy: Is another program (like Arduino IDE, Serial Monitor, or another Python instance) using your COM port?
-
Drivers: If the COM port doesn't show up in your Device Manager, you may need to install the CH340/CP2102 drivers for the adapter board.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file servo_tester-0.1.5.tar.gz.
File metadata
- Download URL: servo_tester-0.1.5.tar.gz
- Upload date:
- Size: 6.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8b90cb10dfcc9c077c8a161efe7c292a192125d2dde478702d8241b75fbad50e
|
|
| MD5 |
d671d05a1627e144b577f9dccd644320
|
|
| BLAKE2b-256 |
e1b6d862920a6bf2225a43094567ff4fc9af63d6e0761e6bbc313f9f1e7767c2
|
Provenance
The following attestation bundles were made for servo_tester-0.1.5.tar.gz:
Publisher:
python-publish.yml on N30Yang/Servotester
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
servo_tester-0.1.5.tar.gz -
Subject digest:
8b90cb10dfcc9c077c8a161efe7c292a192125d2dde478702d8241b75fbad50e - Sigstore transparency entry: 1247109451
- Sigstore integration time:
-
Permalink:
N30Yang/Servotester@7ff940777bc1f05fc92145f208cfd5a014046790 -
Branch / Tag:
refs/tags/v0.1.5 - Owner: https://github.com/N30Yang
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@7ff940777bc1f05fc92145f208cfd5a014046790 -
Trigger Event:
release
-
Statement type:
File details
Details for the file servo_tester-0.1.5-py3-none-any.whl.
File metadata
- Download URL: servo_tester-0.1.5-py3-none-any.whl
- Upload date:
- Size: 7.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7c68a70159ad738507fedb25e23d64f0317bcb43a2b61bc81e85d3df6401b67d
|
|
| MD5 |
73edf79eb43be1b74e5b1ece7928b443
|
|
| BLAKE2b-256 |
fad92550a6ac1769a0f03ddfbd134b5a3798735548d9100f3a611e52fda07cc0
|
Provenance
The following attestation bundles were made for servo_tester-0.1.5-py3-none-any.whl:
Publisher:
python-publish.yml on N30Yang/Servotester
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
servo_tester-0.1.5-py3-none-any.whl -
Subject digest:
7c68a70159ad738507fedb25e23d64f0317bcb43a2b61bc81e85d3df6401b67d - Sigstore transparency entry: 1247109455
- Sigstore integration time:
-
Permalink:
N30Yang/Servotester@7ff940777bc1f05fc92145f208cfd5a014046790 -
Branch / Tag:
refs/tags/v0.1.5 - Owner: https://github.com/N30Yang
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@7ff940777bc1f05fc92145f208cfd5a014046790 -
Trigger Event:
release
-
Statement type: