This repository contains the source code for Cricket UI, a standalone desktop application for interactively controlling MCCI USB Switches in a convenient way. The application supports MCCI Model 3141,3142, 3201, 2301 and 2101 USB Switches.
Note: Prepackaged, signed releases are available at COLLECTION-Cricket-UI/releases
. Only use this repository directly if you want to do source code development.
- List of Contents
- About the Application
- Prerequisites for running or building
- Cricket API Library
- Running the code
- Version change process
- GUI Preview
- Supported Products
- Release History
- Meta
This application is a simple user interface for MCCI USB Switches. It supports manual and automated testing of USB hosts and devices, by automatically connecting and disconnecting USB devices and tracking results.
Development environment
- OS - Windows 10 64 bit
- Python - 3.7.6
- wxPython - 4.0.7.post2
- pyserial - 3.4
- pyusb - 1.0.2
- hidapi - 0.11.2
- matplotlib - 1.16.0
Download python3.7.6 and install.
pip install wxpython==4.0.7.post2
pip install pyserial
pip install pyusb
pip install hidapi == 0.11.2
pip install matplotlib
Development environment
- Linux OS - Ubuntu 20.04 64 bit
- Python - 3.8.2
- wxPython - 4.0.7.post2
- pyserial - 3.4
- pyusb - 1.0.2
- libusb - 1.0.22b9
- libusb1 - 1.8
- hidapi - 0.11.2
- matplotlib - 3.5
sudo apt-get update
sudo apt-get install python3
sudo apt-get install python3-pip
sudo pip3 install wxpython==4.0.7.post2
sudo pip3 install pyserial
sudo pip3 install pyusb
sudo pip3 install libusb
sudo pip3 install libusb1
sudo pip3 install hidapi == 0.11.2
sudo pip3 install matplotlib
Note:
- If the installation of wxPython does not succeed, try
sudo apt-get install build-essential libgtk-3-dev
- Sometimes the installation of wxPython takes a long time (>30 minutes).
Development environment
- Mac OS - Catalina 10.15.7 64 bit
- Python - 3.6.9
- wxPython - 4.0.7.post2
- pyserial - 3.4
- pyusb - 1.0.2
- libusb - 1.0.22b9
- libusb1 - 1.8
- matplotlib - 3.2.2
- hidapi - 0.11.2
sudo apt-get update
sudo apt-get install python3
sudo apt-get install python3-pip
sudo pip3 install wxpython==4.0.7.post2
sudo pip3 install pyserial
sudo pip3 install pyusb
brew install libusb
sudo pip3 install libusb1
sudo pip3 install matplotlib
brew install hidapi - Only for Mac OS
Development environment
- Raspberry Pi OS - aarch64 in Ubuntu 20.04 bit
- Python - 3.6.9
- wxgtk-4.0
- pyserial - 3.5
- pyusb - 1.1.1
- libusb - 1.0.23b7
- libusb1 - 1.9
- hidapi - 0.11.2
- matplotlib - 1.14.0
sudo add-apt-repository ppa:swt-techie/wxpython4
sudo apt-get update
sudo apt-get install python3-wxgtk4.0
sudo pip3 install pyserial
sudo pip3 install pyusb
sudo pip3 install libusb
sudo pip3 install libusb1
sudo pip3 install hidapi==0.11.2
sudo pip3 install matplotlib
Note:
- If the installation of wxPython does not succeed, try
sudo apt-get install build-essential libgtk-3-dev
cricketlib
api is a python library, this libabry intract with Cricket UI
-
download the cricketlib from here crickelib
-
To install the library using below command and install package in Windows OS.
python setup.py install
- To install the library using below command and install package in Linux OS
sudo python3 setup.py install
- To install the library using below command and install package in MacOS
sudo python3 setup.py install
Please navigate to dist/ directory and you will find the files .egg file. Example: cricketapi-1.0.6-py3.7.egg
here provide the REAMDME.md information about cricket lib please follow the instrunctions README
Move to the directory destdir/src/
Run the below command
For Windows:
python main.py
For Linux
python3 main.py
For Mac
python3.6 main.py
For Raspberry Pi
python3 main.py
To update the version for each release
- Move to the directory
destdir/src/
- Open the file
uiGlobals.py
- Update the value of the String Macro
APP_VERSION
- Update the VERSION.md
destdir/VERSION.md
-
The Model 3141 USB4 Switch is a computer-controlled programmable 2:1 switch, connecting two USB Type-C® receptacles to a single USB-C® plug. It is compatible with USB4 hosts and devices, as well as older protocols such as Thunderbolt™ 3, USB 3.2 gen2 or gen1, USB 2.0, USB Type-C Alternate Modes, and of course Power Delivery. It can be used in stress testing, switching between peripherals (for example, a dock and a display), or any automated reconfiguration of a USB Type-C port
Link: For more information, see the product home page.
- The MCCI Model 3201 (MUTT ConnEX-C) plugs and unplugs up to 4 devices for automated testing of USB Type-C® products. Developed in conjunction with Microsoft, the 3201 is upward compatible with the MCCI Model 3101/Model 3201 Connection Exercisers and the Microsoft MUTT ConnEx-C, but has a number of significant enhancements and improvements.
Link: For more information, see the product home page
- The MCCI® Model 3142 USB4 Switch is a computer-controlled programmable 2:1 switch, connecting two USB Type-C® receptacles to a single Type-C plug. It is compatible with USB4 hosts and devices at signaling rates up to 40 gigabits/second, as well as other protocols such as Thunderbolt™ 4, Thunderbolt™ 3, USB 3.2, USB 2.0, USB Type-C Alternate Modes, and of course USB Power Delivery. It also supports Extended Power Range (EPR) sources and sinks, allowing it to be used with source and sinks at up to 48V at 5A.
Link: For more information, see the product home page at MCCI USB4 Switch 3142.
The MCCI USB 3.0 Connection Exerciser MCCI USB Switch 2101 automatically connects and disconnects a USB 2.0 or 3.2 gen1 host and device under push-button or software control. Connections can be single-stepped or repeated. The manual modes are useful for debugging attach/detach scenarios. The MCCI USB 3141 USB4 Switch automates connect/disconnect of one or two devices to a USB Type-C port. It can be used in stress testing, switching between peripherals (for example, a dock and a display), or any automated reconfiguration of a USB Type-C port
Link: For more information, see the product home page at MCCI USB Switch 2101.
The MCCI USB Switch 2301 Type-A Connection Exerciser provides a four-to-one USB switch to automate interoperability tests for systems USB 3.2 gen1 or gen2. It uses the supplied Arduino-based controller and electronic switches to electrically plug and unplug any of the four different input ports. The Gen2-capable Type-B plug can be connected to either of two Type-A receptacles, to a Standard-A receptacle (USB 2.0 only), or a Micro-B receptacle (USB 2.0 only). The Type-A Gen2 receptacles support USB 3.2 (gen 1 and gen 2) and USB 2.0 (high speed, full speed and low-speed) devices. The Standard-A receptacle supports USB 2.0 devices. . For more information, see the product home page atwww.mcci.com.
Link: For more information, see the product home page at MCCI USB Switch 2301.
-
v4.3.0 is patch release it contains the following changes.
-
v4.2.0 is patch release it contains the following changes.
- Add USB4/Thunderbolt4 Tree window #118 Tree Window
- Add Support for USB4/TB4 speed infomation#106 USB4 speed info
- Updated Config file #config file
- Update USB info in status bar#124
-
v4.1.0 is patch release it contains the following changes.
-
added feature for Updated software notification#113
-
Add support for swtich 3142 in Cricket UI
-
-
v4.0.0 is major release it Contains the following changes
-
Added support for MCCI USB Switch 3142 #103 Cricket UI Supports Swicth3142.
-
Firmware update feature added for 3141 and 3142#104 Add firmware update support through USB Serial for 3141 and 3142 USB Swicth.
-
USB VBUS VI Plot improved#105 Adding VI chart support for Switch3142 .
-
-
v3.1.0 is patch release it contains the following changes
- Added for TB4 speed Support in Mac #96 Support TB4 speed
- Showing of warning dialog in batch mode #99
- Increase of minimum delay from 500 msec to 1000 msec #100
- Add delay when switch ports#98
-
v3.0.0 is major release it Contains the following changes
-
Incorrect view showing in Log window while using USB4 hub #77
-
supporting of Thunderbolt device tree view #78
-
Segmentation Fault11 #79
-
No switch connected on Linux; UI seems to show a 2101 #80 #81 #83
-
DUT related issues #90
-
Connecting to switch with manual control doesn't reflect switch state #64
-
Read port status #91
-
Alternate duty cycle calculation #92
-
-
v2.7.1 is a patch release
-
v2.7.0 is a patch release.
- Cricket UI fails to launch on ubuntu 20.04 and 22.04
-
v2.6.1 is a patch release.
- update the version tag #75
-
v2.6.0 is a patch release.
- Device search dialog goes blank until complete the search #70
- App not responding when other com port devices(that are not MCCI USB Switches) are attached to the system USB & Slow search for switches #59 #65
- Minimizing and maximizing the application #60
- Disable VBUS V/I monitor if switch doesn't support #63
- misspelling in the log window instead of Switch it was spelled as Swicth #61.
-
v2.5.0 is major release it Contains the following changes
-
Feature added – Plotting of VBUS Volt and Current
VBUS V/I Plotting
#18 #48 #52. -
USB Tree view removed and merged with Log Window
Replaced USB Tree view window to Log Window
#24. -
Perform device Search in advance, Device searching automatically or manually searching the device
USB Switch Scanning
#30. -
Auto mode improved (Port selection provided)
Port(s) selection
#22 also with out port selection start auto pop-pp window appearsPopUp window
#Auto Popupwindow
. -
Linux machine IP scanning issue fixed
Scanning ip address from Linux machine
#20. -
The word Model replace by MCCI USB Switch
Replace MCCI USB Switch
#27. -
UI not responding issued fixed
UI not Responding
#28. -
Do not disable Manage Model>Connect when connected allow the user to directly connect to another switch
Connect menu
#30. -
Enhancement – Highlight the name of the Switch
Highlet Switch
#29. -
added Finished count in Loop Mode
Finished Count
#23. -
Persistence of last connect
Last device connect
#43 -
Application hangs when closing the application on macOS using Quit command #40.
-
click on the settings menu, then click on the "Switch Control Computer" sub menu, this should display a dialog for searching the Computer over the network based on the port assigned for that. But dialog does not appearing
SCC and THC Setting menu search dialog not displayed - In Mac Catalian and Monterey
#41. -
UI panel are not centralized
fixed UI in Central on window
45. -
Port selection should be disable state once the Auto mode execution get started, then the required ports are should be enabled when auto mode gets stopped
Disable the port selection when auto mode is under execution
#50 -
update Cricket UI Windows.spec file with One directory file
Update Cricket-Windows.spec file
#47. -
Update year in the copy right info
Update copy right info in About dialog
#53
-
-
v2.4.0 is major release; changes are significant to networking using TCP/IP.
- Add new feature support for Three computer System and Two Computer
Two and Three Computer system through Networking
#14.
- Add new feature support for Three computer System and Two Computer
-
v2.3.0 is major release has following changes.
- Add support for MCCI Switch 2301 USB Connection Exerciser
MCCI USB Switch 2301
#4.
- Add support for MCCI Switch 2301 USB Connection Exerciser
-
v2.2.0 has following changes:
- Python implemented to Pep8 coding standard
MCCI USB Switch 2301
#5. - Package release for Raspberry Pi OS ubuntu18.04
- Python implemented to Pep8 coding standard
-
v2.0.0 is a major release.
- Interface for USB Switch 2101 added
- Radio buttons for Port switching replaced by image added buttons,
- Duty parameter added in auto mode,
- Until stopped and Port selection option added to the Loop mode and separate panel for Auto mode added,
- adding USB speed info, increase port switching speed.
-
v1.2.0 has following changes
- Host Controller issue and Delay override
-
v1.0.2 is a changes to menu option
- Mac Menu Update
-
v1.0.0 initial release of cricket UI
- Initial Release
Except as explicitly noted, content created by MCCI in this repository tree is copyright (C) 2021-2022, MCCI Corporation.
The Cricket UI is released under the terms of the attached GNU General Public License, version 2. LICENSE.md
is taken directly from the FSF website.
Commercial licenses and commercial support are available from MCCI Corporation.
Git submodules are subject to their own copyrights and licenses; however overall collection is a combined work, and is copyrighted and subject to the overall license.
MCCI invests time and resources providing this open source code, please support MCCI and open-source hardware by purchasing products from MCCI and other open-source hardware/software vendors!
For information about MCCI's products, please visit store.mcci.com.
MCCI and MCCI Catena are registered trademarks of MCCI Corporation. USB4, USB Type-C and USB-C are registered trademarks of USB-IF. All other marks are the property of their respective owners.