esp-idf-v4.3-build.yml 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. # This is a basic workflow to help you get started with Actions
  2. name: ESP-IDF v4.3.1
  3. on:
  4. push:
  5. branches:
  6. - '**4.3'
  7. pull_request:
  8. branches:
  9. - '**4.3'
  10. jobs:
  11. job1:
  12. name: Build Number
  13. runs-on: ubuntu-latest
  14. outputs:
  15. build_number: ${{ steps.buildnumber.outputs.build_number }}
  16. steps:
  17. - name: Generate common build number
  18. id: buildnumber
  19. uses: einaregilsson/build-number@v3
  20. with:
  21. token: ${{secrets.github_token}}
  22. build:
  23. runs-on: ubuntu-latest
  24. needs: job1
  25. strategy:
  26. max-parallel: 1
  27. matrix:
  28. node: [I2S-4MFlash, SqueezeAmp]
  29. depth: [16, 32]
  30. steps:
  31. - name: Set target name
  32. run: |
  33. echo "TARGET_BUILD_NAME=${{ matrix.node }}" >> $GITHUB_ENV
  34. echo "build_version_prefix=1." >> $GITHUB_ENV
  35. - uses: actions/checkout@v2
  36. with:
  37. fetch-depth: 15
  38. submodules: true
  39. - name: Cache build
  40. id: cache-build
  41. uses: actions/cache@v2
  42. with:
  43. path: |
  44. build
  45. /var/lib/docker
  46. key: idf4.3-${{ runner.os }}-${{ matrix.node }}-${{ matrix.depth }}
  47. - name: Set build parameters
  48. run: |
  49. git update-index --chmod=+x ./server_certs/getcert.sh
  50. git update-index --chmod=+x ./components/spotify/cspot/bell/nanopb/generator/protoc
  51. cd server_certs;./getcert.sh;cat github.pem;cd ..
  52. shopt -s nocasematch
  53. branch_name="${GITHUB_REF//refs\/heads\//}"
  54. branch_name="${branch_name//[^a-zA-Z0-9\-~!@_\.]/}"
  55. BUILD_NUMBER=${{ needs.job1.outputs.build_number }}
  56. echo "BUILD_NUMBER=${BUILD_NUMBER}" >> $GITHUB_ENV
  57. echo "DOCKER_IMAGE_NAME=sle118/squeezelite-esp32-idfv4-master" >> $GITHUB_ENV
  58. tag="${TARGET_BUILD_NAME}.${{matrix.depth}}.${BUILD_NUMBER}.${branch_name}"
  59. echo "tag=${tag}" >> $GITHUB_ENV
  60. last_commit="$(git log --pretty=format:'%s' --max-count=1)"
  61. if [[ "$last_commit" =~ .*"Release".* ]]; then echo "release_flag=1" >> $GITHUB_ENV; else echo "release_flag=0" >> $GITHUB_ENV; fi
  62. name="1.${BUILD_NUMBER}-${{matrix.depth}}#v4.0#${TARGET_BUILD_NAME}#${branch_name}"
  63. artifact_prefix="squeezelite-esp32-${branch_name}-${TARGET_BUILD_NAME}-${{matrix.depth}}-${build_version_prefix}${BUILD_NUMBER}"
  64. artifact_file_name="${artifact_prefix}.zip"
  65. artifact_bin_file_name="${artifact_prefix}.bin"
  66. echo "name=${name}" >> $GITHUB_ENV
  67. echo "last_commit=${last_commit}" >> $GITHUB_ENV
  68. echo "artifact_file_name=${artifact_file_name}" >> $GITHUB_ENV
  69. echo "PROJECT_VER=${TARGET_BUILD_NAME}-${{ steps.buildnumber.outputs.build_number }} " >> $GITHUB_ENV
  70. echo "artifact_bin_file_name=${artifact_bin_file_name}" >> $GITHUB_ENV
  71. description=""
  72. description=${description}$'------------------------------\n### Revision Log\n\n'
  73. description="$description$(git log --pretty=format:'%h %s (%cI) <%an>' --abbrev-commit --max-count=15 | sed --r 's/(^[\*]+)/\\\1/g') "
  74. echo 'description<<~EOD' >> $GITHUB_ENV
  75. echo ${description}>> $GITHUB_ENV
  76. echo '~EOD' >> $GITHUB_ENV
  77. echo #######
  78. echo ####### Environment
  79. echo #######
  80. env
  81. echo #######
  82. echo ####### GITHUB ENV
  83. echo #######
  84. cat $GITHUB_ENV
  85. - name: Build the firmware
  86. run: |
  87. env | grep "artifact\|tag\|GITHUB\|version\|NUMBER\|TARGET" >${TARGET_BUILD_NAME}-env.txt
  88. echo "${tag}" >version.txt
  89. echo pulling custom docker image ${DOCKER_IMAGE_NAME}
  90. docker pull ${DOCKER_IMAGE_NAME}
  91. docker run --env-file=${TARGET_BUILD_NAME}-env.txt -v $PWD:/project -w /project ${DOCKER_IMAGE_NAME} /bin/bash -c "pushd components/wifi-manager/webapp/ && npm install && npm run-script build && popd"
  92. docker run --env-file=${TARGET_BUILD_NAME}-env.txt -v $PWD:/project -w /project ${DOCKER_IMAGE_NAME} /bin/bash -c "cp build-scripts/${TARGET_BUILD_NAME}-sdkconfig.defaults sdkconfig"
  93. docker run --env-file=${TARGET_BUILD_NAME}-env.txt -v $PWD:/project -w /project ${DOCKER_IMAGE_NAME} /bin/bash -c "idf.py build -DDEPTH=${{ matrix.depth }} -DBUILD_NUMBER=${BUILD_NUMBER}-${{ matrix.depth }} "
  94. docker run --env-file=${TARGET_BUILD_NAME}-env.txt -v $PWD:/project -w /project ${DOCKER_IMAGE_NAME} /bin/bash -c "zip -r build_output.zip build && zip build/${artifact_file_name} partitions*.csv build/*.bin build/bootloader/bootloader.bin build/partition_table/partition-table.bin build/flash_project_args build/size_*.txt"
  95. # - name: Build Mock firmware
  96. # run: |
  97. # mkdir -p build
  98. # cd build
  99. # mkdir -p partition_table
  100. # mkdir -p bootloader
  101. # echo "mock content"> squeezelite.bin
  102. # echo "mock content"> recovery.bin
  103. # echo "mock content"> ./bootloader/bootloader.bin
  104. # echo "mock content"> ./partition_table/partition-table.bin
  105. # echo "mock content"> flash_project_args
  106. # echo "mock content"> size_comp1.txt
  107. # echo "mock content"> size_comp2.txt
  108. # echo "mock content"> ../partitions.csv
  109. - uses: actions/upload-artifact@v2
  110. with:
  111. name: ${{ env.artifact_file_name }}
  112. path: |
  113. build/*.bin
  114. build/bootloader/bootloader.bin
  115. build/partition_table/partition-table.bin
  116. build/flash_project_args
  117. build/size_comp1.txt
  118. build/size_comp2.txt
  119. partitions.csv
  120. sdkconfig
  121. server_certs/github.pem
  122. build_output.zip
  123. - uses: actions/upload-artifact@v2
  124. with:
  125. name: ${{ env.artifact_bin_file_name }}
  126. path: |
  127. build/squeezelite.bin
  128. - name: Create Release
  129. if: env.release_flag == 1
  130. id: create_release
  131. uses: actions/create-release@v1
  132. env:
  133. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # This token is provided by Actions, you do not need to create your own token
  134. with:
  135. tag_name: ${{ env.tag }}
  136. release_name: ${{ env.name }}
  137. body: ${{ env.description }}
  138. draft: false
  139. prerelease: true
  140. - name: Upload Release Asset - Squeezelite binary file
  141. if: env.release_flag == 1
  142. id: upload-release-asset
  143. uses: actions/upload-release-asset@v1
  144. env:
  145. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  146. with:
  147. upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps
  148. asset_path: build/squeezelite.bin
  149. asset_name: ${{ env.artifact_bin_file_name }}
  150. asset_content_type: application/octet-stream
  151. - name: Upload Release Asset - Zip file
  152. if: env.release_flag == 1
  153. id: upload-release-asset-zip
  154. uses: actions/upload-release-asset@v1
  155. env:
  156. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  157. with:
  158. upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps
  159. asset_path: build/${{ env.artifact_file_name }}
  160. asset_name: ${{ env.artifact_file_name }}
  161. asset_content_type: application/octet-stream