/image-builder-odroid-xu4

Build SD card image for ODROID XU4

Primary LanguageRubyMIT LicenseMIT

image-builder-odroid-xu4

Join the chat at https://gitter.im/hypriot/talk Build Status

PLEASE NOTE: This repo is currently not maintained.

This repo builds the SD card image with HypriotOS for the ODROID XU4 board. To build this SD card image we have to

  • take the files for the root filesystem from os-rootfs
  • add Hypriot's Debian repos
  • install the ODROID kernel
  • install Docker tools Docker Engine, Docker Compose and Docker Machine

Here is an example how all the GitHub repos play together:

Architecture

Contributing

You can contribute to this repo by forking it and sending us pull requests. Feedback is always welcome!

You can build the SD card image locally with Vagrant.

Setting up build environment

Make sure you have vagrant and docker-machine installed. Then run the following command to create the Vagrant box and the Docker Machine connection. The Vagrant box is needed as a vanilla boot2docker VM is not able to run guestfish inside.

make docker-machine

Now set the Docker environments to this new docker machine:

eval $(docker-machine env image-builder-odroid-xu4)

Build the SD card image

From here you can just make the SD card image. The output will be written and compressed to hypriotos-odroid-xu4-dirty.img.zip.

make sd-image

Run Serverspec tests

To test the compressed SD card image with Serverspec just run the following command. It will expand the SD card image in a Docker container and run the Serverspec tests in builder/test/ folder against it.

make test

Run integration tests

Now flash the SD card image and boot up a ODROID xu4. Run the Serverspec integration tests in builder/test-integration/ folder against your ODROID xu4. Set the environment variable BOARD to the IP address or host name of your running ODROID xu4.

flash hypriotos-odroid-xu4-dirty.img.zip
BOARD=black-pearl.local make test-integration

This test works with any Docker Machine, so you do not need to create the Vagrant box.

Deployment

For maintainers of this project you can release a new version and deploy the SD card image to GitHub releases with

TAG=v0.0.1 make tag

After that open the GitHub release of this version and fill it with relevant changes and links to resolved issues.

License

MIT - see the LICENSE file for details.