Combination of the rig orchastration server & the client code that runs on each host.
git submodule update --init --recursive
Only Linux fully supports running the tests and OSX partially supports the test bench. The SMT tests use a pyOCD
dependency which has some inaccessible features on OSX. Running the server and client will work on OSX, but the test bench will fail after SMT tests are commenced (specifically, on the 'boot' test). Through hole tests work fine on OSX. Windows has been untested.
The server is currently managed using Dokku. You'll need to have ssh access to deploy updates to the server, but do not need to ssh into the server.
Add dokku
as a git remote:
git remote add dokku [email protected]
Once that remote is added, the official CLI client can be used to manage the server.
A complete update of the test bench code consists of four parts: updating the release binaries (also known as golden images), updating the test bench, updating the boot scripts (in the /boot
folder), and updating the server
code running at testalator.tessel.io
.
Most use cases likely involve only updating the binaries flashed on to the new Tessels. Updating the test runner or boot code is a significant endeavor and should only be attempted when absolutely necessary to prevent manufacturing delays. Updating the server
code is relatively straightforward but shouldn't be necessary in most cases.
Occasionally, we may want to update the version of the binaries that our manufacturers are flashing on Tessel 2s as they come off the assembly line. To do that, you will need SSH access to the Testalator server (testalator.tessel.io). If you don't have access, please ask another Tessel Team Member.
$ Transfer the binaries to a publicly accessible directory on the test server
scp firmware.bin [email protected]:/var/lib/dokku/data/storage/testalator/
scp openwrt-ramips-mt7620-tessel-squashfs-sysupgrade.bin [email protected]:/var/lib/dokku/data/storage/testalator/
The testbench consists of the entire \client
directory with the exception of any node_modules
with binary dependencies (they will have to be re-installed on the machine). Updating the testbench consists of tarring up the client
directory and sending it to the public builds repo of testalator.tessel.io
. A build script will download this tarball when test running laptops at manufacturer's locations boot up.
# Zips up the client to the local `server`'s build directory
tar -cvz --exclude-from=.client-tar-ignore -f server/public/builds/client.tar.gz .
$ Transfers the tarball to a publicly accessible directory on the test server
scp server/public/builds/client.tar.gz [email protected]:/var/lib/dokku/data/storage/testalator/
You should also update the config.json
file to have the correct commit sha for the version of the client you are uploading. Once that is updated and commited, it can be pushed to the dokku server:
git push dokku master
Updating the boot script code (in the /boot
directory) lives on the same flash drives that contain the debian live image that is powering the test running PC. To update it, you'll either net to get access to the flash drive currently in use at the manufacturer's facility or you'll need to send them new ones. Load the debian image onto the flash drive, boot into it, then place the contents of the /boot
folder into /lib/live/mount/medium
folder.
Updates can be deploy by pushing to the dokku
remote:
git push dokku master
Dokku will automatically build, deploy, and restart the server with these changes.