Skip to main content

Python libraries to talk to IQ Motion Control devices

Project description

IQ Motion Python API

Python Build codecov tag release

This library is to talk to any IQ Control devices from mulititude of communication protocols.

Getting Started

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
To Learn more about this API, Read the Communications API Documentation

Prerequisites

Pipenv

Read the second part of this and this for more information on pipenv.

Windows and mac users:

Linux users:

Installing

You can install this library using "pipenv" or "pip":

pipenv install iqmotion

or

pip install iqmotion

If you want to edit this library and/or run some tests, You can clone this repository locally on your computer.

Submodule

If you are using this repository as a submodule, make sure to make a symbolic link:

ln -s python_api/iqmotion iqmotion

If you prefer not to use symbolic links, you could dynamically append the library to your system PATH at runtime by following along with the example below:

├── examples    ├── api_testing.py <---------------(current python script)   ├── async_example.py
│   ├── multi_turn_example.py
│   └── propeller_example.py
├── iqmotion   <-----------------------(IQMOTION API LIBRARY)   ├── client_entries
│      ├── client_entry_data.py
│      ├── client_entry.py
│      ├── dictionary_client_entry.py
│      ├── __init__.py
│      └── process_client_entry.py
│   ├── clients

If you wanted to run api_testing.py from the examples Directory, you would need to append the iqmotion library to the system path at the top of my api_testing.py script:

import sys

#  Adds the parent directory to the system path 
# (Same location that the iqmotion library is located)
sys.path.append("../") 

Running the tests

You will need the following packages to run the tests:

  • pytest
  • pytest-cov

They should be already installed with pipenv.

You can then run the software tests with the following command:

pytest ./iqmotion/tests/ --cov-config=.coveragerc --cov=iqmotion --cov-fail-under=100

The test will fail if coverage is under 100%

You can run the hardware tests with the following commands:

python run_hardware_tests.py speed --usb_handle=/dev/ttyUSB0
python run_hardware_tests.py servo --usb_handle=/dev/ttyUSB0
python run_hardware_tests.py step_dir --usb_handle=/dev/ttyUSB0

Clean Code

Formatting

We use black as a formatter. It does everything for you and it should be installed with the dev packages of pipenv.
I recommend setting up your IDE to format with black when saving. Vscode has a known issue sometimes with new .py files where you need to run black in the terminal first You can also run black from the terminal with:

black ./

Linting

We use pylint as a linter. It does everything for you and it should be installed with the dev packages of pipenv.
We have a .pylintrc file that setups your pylint for you.

I would recommend to set up your IDE to use pylint automatically (vscode should find the .pylintrc automatically).

Sometimes pylint shouts at out some errors you do not wantc you can disbale a pylint error locally in a file/method/class with a comment like this:

# pytlint: disable=my-error

You can also run pylint from the terminal with the following command:

pylint your_project_directory

New Releases

It is really easy to create a new release, simply run the following script and follow the prompt:

(You might need to run the following command to use a bash script in windows):

dos2unix ./ci_scripts/new_release.sh
./ci_scripts/new_release.sh

Versioning

We use SemVer for versioning.

Contributing

Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.

Authors

  • Raphael Van Hoffelen
  • Malik B. Parker

See also the list of contributors who participated in this project.

License

This project is licensed under the MIT License - see the LICENSE file for details

Acknowledgments

  • Matt Piccoli for helping out debugging the architecture and continuously testing the API.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

iqmotion-0.24.2.tar.gz (37.7 kB view details)

Uploaded Source

Built Distribution

iqmotion-0.24.2-py2.py3-none-any.whl (62.0 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file iqmotion-0.24.2.tar.gz.

File metadata

  • Download URL: iqmotion-0.24.2.tar.gz
  • Upload date:
  • Size: 37.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.8.2

File hashes

Hashes for iqmotion-0.24.2.tar.gz
Algorithm Hash digest
SHA256 c96a96c4f918cc5e702e00878f5429ca05f07587be4b9ffd8d52e01defac4a2e
MD5 142bebd30d4bf0a7d159b52b524ebdbe
BLAKE2b-256 874e155a9eed118fd318aa7a628d252661d8adc62ed930efd1138209adbf8daf

See more details on using hashes here.

File details

Details for the file iqmotion-0.24.2-py2.py3-none-any.whl.

File metadata

  • Download URL: iqmotion-0.24.2-py2.py3-none-any.whl
  • Upload date:
  • Size: 62.0 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.8.2

File hashes

Hashes for iqmotion-0.24.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 4bbd71f9a6b91268527b2a56f2adb427e8f5f631d7d7af837c419395202ae536
MD5 89302258b7075cbb3bf0d6e124571603
BLAKE2b-256 369ebed7560ec23af45e994925c59e5d8ade887d68412cb1f64f56c05d848dcc

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page