From 7db2726eb29ecef9691062b2c9fc2144c20a0a37 Mon Sep 17 00:00:00 2001 From: Sacha Weatherstone Date: Tue, 8 Mar 2022 23:12:46 +1100 Subject: [PATCH] Update publish.md --- docs/developers/publish.md | 65 ++++++++++++++++++++------------------ 1 file changed, 35 insertions(+), 30 deletions(-) diff --git a/docs/developers/publish.md b/docs/developers/publish.md index f9db34a9..a7ae6742 100644 --- a/docs/developers/publish.md +++ b/docs/developers/publish.md @@ -10,9 +10,9 @@ If you’d like to do ‘real’ releases with your changes, the procedure is: ## Device -* Update protobufs +- Update protobufs -``` +```bash cd proto git checkout master && git pull cd .. @@ -21,36 +21,34 @@ git commit -m "updating proto submodule to latest" run bin/regen-protos.sh ``` -* edit version.properties to set release version -* commit and push (or merge) to root of repo - this should cause GitHub to start a release build (see the CI actions) -* edit the draft release text and click publish +- edit version.properties to set release version +- commit and push (or merge) to root of repo - this should cause GitHub to start a release build (see the CI actions) +- edit the draft release text and click publish ### Update Protobufs - ## Android ### Pre-requisites -* Add repository secrets -* * KEYSTORE_FILENAME -* * * name of the .jks -* * KEYSTORE -* * * we will convert the .jks to base64 -* * * openssl base64 < filename.jks | tr -d '\n' | tee filename.txt -* * KEYSTORE_PROPERTIES -* * * storePassword=nononononono -keyPassword=nononononono -keyAlias=upload -storeFile=nononononono.jks - +- Add repository secrets +- - KEYSTORE_FILENAME +- - - name of the .jks +- - KEYSTORE +- - - we will convert the .jks to base64 +- - - openssl base64 < filename.jks | tr -d '\n' | tee filename.txt +- - KEYSTORE_PROPERTIES +- - - storePassword=nononononono + keyPassword=nononononono + keyAlias=upload + storeFile=nononononono.jks ### Instructions - Automated -* Update protobufs -* Go to Actions / Make Release / Run Workflow -* Pick the Releases branch -* Enter the version found in app/gradle.build +- Update protobufs +- Go to Actions / Make Release / Run Workflow +- Pick the Releases branch +- Enter the version found in app/gradle.build ## iOS @@ -62,8 +60,8 @@ A `meshtastic-flasher` release consists of publishing the release to PyPi https: ### Instructions - automated -* Go to Actions / Make Release / Run Workflow https://github.com/meshtastic/Meshtastic-gui-installer/actions/workflows/release.yml -* Draft & Publish release https://github.com/meshtastic/Meshtastic-gui-installer/releases +- Go to Actions / Make Release / Run Workflow https://github.com/meshtastic/Meshtastic-gui-installer/actions/workflows/release.yml +- Draft & Publish release https://github.com/meshtastic/Meshtastic-gui-installer/releases ## Python @@ -82,9 +80,9 @@ pip install . ### Instructions -* Update protobufs by running the "Update protobufs" workflow in Actions: https://github.com/meshtastic/Meshtastic-python/actions/workflows/update_protobufs.yml +- Update protobufs by running the "Update protobufs" workflow in Actions: https://github.com/meshtastic/Meshtastic-python/actions/workflows/update_protobufs.yml -* run the "smoke1" test (optional): +- run the "smoke1" test (optional): connect one device to the serial port and run: @@ -92,14 +90,21 @@ connect one device to the serial port and run: pytest -m smoke1 ``` -* run unit tests: `pytest` (optional) +- run unit tests: `pytest` (optional) -* run bin/test-release.sh (optional) +- run bin/test-release.sh (optional) -* Run the "Make Release" workflow in Actions: https://github.com/meshtastic/Meshtastic-python/actions/workflows/release.yml +- Run the "Make Release" workflow in Actions: https://github.com/meshtastic/Meshtastic-python/actions/workflows/release.yml -* After the "Make Release" is done, go into Releases: https://github.com/meshtastic/Meshtastic-python/releases There should be a draft. Add the title, update the "What's Changed" (Tip: Click on the "Auto-generate release notes" button.). Uncheck the "This is a pre-release" (if applicable). +- After the "Make Release" is done, go into Releases: https://github.com/meshtastic/Meshtastic-python/releases There should be a draft. Add the title, update the "What's Changed" (Tip: Click on the "Auto-generate release notes" button.). Uncheck the "This is a pre-release" (if applicable). :::note You need permissions in the GitHub project to make a build ::: + +## Web + +Releases are automatically generated for every commit as per out [CI](https://github.com/meshtastic/meshtastic-web/blob/master/.github/workflows/main.yml). This performs two actions: + +1. Generates a perpetually updated [GitHub release](https://github.com/meshtastic/meshtastic-web/releases/tag/latest) with an accompanying `build.tar` that a automatically get's pulled by the firmware CI at build time. +2. A hosted version is deployed to [client.meshtastic.org](https://client.meshtastic.org).