Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Continous Integration Build of Firmware Artifacts & Fix Build Script #65

Open
wants to merge 4 commits into
base: main
Choose a base branch
from

Conversation

calotlea
Copy link

Add automated checks for firmware build via Github CI script

Instead of setting up all required development tools locally, let github build the firmware on each push to this repo. If this build fails for any reason an error notifcation is sent. Further the build script also uploads the firmware artifacts to github as part of the workflow, allowing users to fetch the latest push.

The workflow further adds a status badge on the front page of the project indicating build success or failure.

actions

  1. Select Actions
  2. Select the Firmware workflow
  3. Download the latest build artifact

Fix of indefinite build loop in scripts/build_interface.py

When -D EMBED_WWW is commented out it forces pio run --target uploadfs in the python build file. Since the process of pio run hasn't completed and the pre-build script is called again, it just indefinitely recurses in.

Further to reduce noise of regenerated files, WWWData.h and was taken out of version control (was already ignored by .gitignore) but still committed.

@leokeba
Copy link
Contributor

leokeba commented Dec 30, 2024

I also made something similar on one of my forks, if anybody is interested : https://github.com/open-heliostat/open-heliostat/blob/main/.github/workflows/release.yml

The main difference is that I did not want to have to manage tags manually because it does not play well with my workflow, so I am using a version.txt file that triggers a release when it's pushed on the main branch. platformio.ini also uses this file as reference. The only other thing I wanted to add but didn't yet was to append the commit hash to the version string when building locally to better keep track of FW versions when developping.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants