Use the native MacOS build as the nightly build uploaded to Bintray (#375)
This commit is contained in:
parent
999c47238d
commit
5a96e94cfe
2
.github/workflows/mac_native.yml
vendored
2
.github/workflows/mac_native.yml
vendored
@ -24,5 +24,5 @@ jobs:
|
|||||||
- uses: actions/upload-artifact@master
|
- uses: actions/upload-artifact@master
|
||||||
with:
|
with:
|
||||||
name: tsMuxer
|
name: tsMuxer
|
||||||
path: build/bin/mac.tar.bz2
|
path: build/bin/mac.zip
|
||||||
name: upload-artefact
|
name: upload-artefact
|
||||||
|
@ -18,6 +18,12 @@ jobs:
|
|||||||
- uses: actions/checkout@master
|
- uses: actions/checkout@master
|
||||||
name: checkout
|
name: checkout
|
||||||
|
|
||||||
|
- run: ./bintray_nightly_check.sh
|
||||||
|
name: nightly-check
|
||||||
|
env:
|
||||||
|
BINTRAY_USER: ${{ secrets.BINTRAY_USER }}
|
||||||
|
BINTRAY_API_KEY: ${{ secrets.BINTRAY_API_KEY }}
|
||||||
|
|
||||||
- run: rm -f bin/.gitkeep
|
- run: rm -f bin/.gitkeep
|
||||||
name: clean-bin-folder
|
name: clean-bin-folder
|
||||||
|
|
||||||
@ -30,9 +36,6 @@ jobs:
|
|||||||
- run: ./rebuild_mxe32_with_gui_docker.sh
|
- run: ./rebuild_mxe32_with_gui_docker.sh
|
||||||
name: build-for-win32
|
name: build-for-win32
|
||||||
|
|
||||||
- run: ./rebuild_osxcross_with_gui_docker.sh
|
|
||||||
name: build-for-mac
|
|
||||||
|
|
||||||
- run: ./bintray_nightly_upload.sh
|
- run: ./bintray_nightly_upload.sh
|
||||||
name: upload-to-bintray-nightly
|
name: upload-to-bintray-nightly
|
||||||
env:
|
env:
|
32
.github/workflows/nightly-mac-native.yml
vendored
Normal file
32
.github/workflows/nightly-mac-native.yml
vendored
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
name: Nightly native Mac build
|
||||||
|
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: '1 15 * * *'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build-mac-native:
|
||||||
|
|
||||||
|
runs-on: macos-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@master
|
||||||
|
name: checkout
|
||||||
|
|
||||||
|
- run: ./bintray_nightly_check.sh
|
||||||
|
name: nightly-check
|
||||||
|
env:
|
||||||
|
BINTRAY_USER: ${{ secrets.BINTRAY_USER }}
|
||||||
|
BINTRAY_API_KEY: ${{ secrets.BINTRAY_API_KEY }}
|
||||||
|
|
||||||
|
- name: Install Qt
|
||||||
|
uses: jurplel/install-qt-action@v2
|
||||||
|
|
||||||
|
- run: ./build_macos_native.sh
|
||||||
|
name: build-for-mac
|
||||||
|
|
||||||
|
- run: ./bintray_nightly_upload.sh ./build/bin/mac.zip mac
|
||||||
|
name: upload-bintray-mac-build
|
||||||
|
env:
|
||||||
|
BINTRAY_USER: ${{ secrets.BINTRAY_USER }}
|
||||||
|
BINTRAY_API_KEY: ${{ secrets.BINTRAY_API_KEY }}
|
40
bintray_nightly_check.sh
Normal file
40
bintray_nightly_check.sh
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# Checks if the commit hash of the current newest nightly build on
|
||||||
|
# Bintray is the same as the current HEAD, in which case returns a
|
||||||
|
# nonzero exit code. Otherwise, tries to create a new "version" in the
|
||||||
|
# Bintray repository.
|
||||||
|
|
||||||
|
# This script should be used as the entry point of "build nightly"
|
||||||
|
# actions in order to prevent unnecessarily triggering builds if nothing
|
||||||
|
# has changed.
|
||||||
|
|
||||||
|
# BINTRAY_USER and BINTRAY_API_KEY must be present in the environment.
|
||||||
|
|
||||||
|
BINTRAY_REPO=tsMuxer
|
||||||
|
PCK_NAME=tsMuxerGUI-Nightly
|
||||||
|
repo_commit=$(curl -s https://dl.bintray.com/$BINTRAY_USER/$BINTRAY_REPO/commit.txt)
|
||||||
|
local_commit=$(git rev-parse HEAD)
|
||||||
|
version_date=$(date +%Y-%m-%d)
|
||||||
|
|
||||||
|
if [[ $repo_commit == $local_commit ]]; then
|
||||||
|
echo "latest nightly build already in bintray!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# create a new version with the timestamp
|
||||||
|
version_data='{ "name": "'
|
||||||
|
version_data+=$version_date
|
||||||
|
version_data+='", "desc": "tsMuxer CLI and GUI binaries built on '
|
||||||
|
version_data+=$version_date
|
||||||
|
version_data+='"}'
|
||||||
|
echo "$version_data"
|
||||||
|
|
||||||
|
version_created=$(curl -u$BINTRAY_USER:$BINTRAY_API_KEY -H "Content-Type: application/json" --write-out %{http_code} --silent --output /dev/null --request POST --data "$version_data" https://api.bintray.com/packages/$BINTRAY_USER/$BINTRAY_REPO/$PCK_NAME/versions)
|
||||||
|
if [[ $version_created -eq 201 ]]; then
|
||||||
|
echo "version $version_date has been created!"
|
||||||
|
else
|
||||||
|
echo "error creating version $version_date : server returned $version_created"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 0 # don't return an error in case the version already exists
|
@ -1,52 +1,46 @@
|
|||||||
#!/bin/bash
|
#!/usr/bin/env bash
|
||||||
# BINTRAY_USER
|
# BINTRAY_USER
|
||||||
# BINTRAY_API_KEY
|
# BINTRAY_API_KEY
|
||||||
|
|
||||||
BINTRAY_REPO=tsMuxer
|
BINTRAY_REPO=tsMuxer
|
||||||
PCK_NAME=tsMuxerGUI-Nightly
|
PCK_NAME=tsMuxerGUI-Nightly
|
||||||
repo_commit=$(curl -s https://dl.bintray.com/$BINTRAY_USER/$BINTRAY_REPO/commit.txt)
|
version_date=$(date +%Y-%m-%d)
|
||||||
local_commit=$(git rev-parse HEAD)
|
|
||||||
version_date=$(date +%Y-%m-%d--%H-%M-%S)
|
|
||||||
|
|
||||||
if [ "$repo_commit" = "$local_commit" ] ; then
|
upload_to_bintray() {
|
||||||
echo "latest nightly build already in bintray!"
|
local localpath="$1"
|
||||||
exit 1
|
local buildname="$2"
|
||||||
else
|
curl -T "$localpath" "-u$BINTRAY_USER:$BINTRAY_API_KEY" \
|
||||||
# create a new version with the timestamp
|
-H "X-Bintray-Package:$PCK_NAME" \
|
||||||
version_data='{ "name": "'
|
-H "X-Bintray-Version:$version_date" \
|
||||||
version_data+=$version_date
|
-H "X-Bintray-Publish:1" \
|
||||||
version_data+='", "desc": "tsMuxer CLI and GUI binaries built on '
|
-H "X-Bintray-Override:1" \
|
||||||
version_data+=$version_date
|
"https://api.bintray.com/content/$BINTRAY_USER/$BINTRAY_REPO/${buildname}-nightly-$version_date.zip"
|
||||||
version_data+='"}'
|
}
|
||||||
echo $version_data
|
|
||||||
version_created=$(curl -u$BINTRAY_USER:$BINTRAY_API_KEY -H "Content-Type: application/json" --write-out %{http_code} --silent --output /dev/null --request POST --data "$version_data" https://api.bintray.com/packages/$BINTRAY_USER/$BINTRAY_REPO/$PCK_NAME/versions)
|
|
||||||
if [ $version_created -eq 201 ] ; then
|
|
||||||
echo "version $version_date has been created!"
|
|
||||||
|
|
||||||
# upload the ZIP files to the version we just created on bintray
|
# when triggered with arguments, just upload the given file and exit.
|
||||||
echo "uploading files..."
|
if [[ "$@" ]]; then
|
||||||
curl -T ./bin/mac.zip -u$BINTRAY_USER:$BINTRAY_API_KEY -H "X-Bintray-Package:$PCK_NAME" -H "X-Bintray-Version:$version_date" -H "X-Bintray-Publish:1" -H "X-Bintray-Override:1" https://api.bintray.com/content/$BINTRAY_USER/$BINTRAY_REPO/mac-nightly-$version_date.zip
|
upload_to_bintray "$@"
|
||||||
curl -T ./bin/w32.zip -u$BINTRAY_USER:$BINTRAY_API_KEY -H "X-Bintray-Package:$PCK_NAME" -H "X-Bintray-Version:$version_date" -H "X-Bintray-Publish:1" -H "X-Bintray-Override:1" https://api.bintray.com/content/$BINTRAY_USER/$BINTRAY_REPO/w32-nightly-$version_date.zip
|
exit 0
|
||||||
curl -T ./bin/w64.zip -u$BINTRAY_USER:$BINTRAY_API_KEY -H "X-Bintray-Package:$PCK_NAME" -H "X-Bintray-Version:$version_date" -H "X-Bintray-Publish:1" -H "X-Bintray-Override:1" https://api.bintray.com/content/$BINTRAY_USER/$BINTRAY_REPO/w64-nightly-$version_date.zip
|
|
||||||
curl -T ./bin/lnx.zip -u$BINTRAY_USER:$BINTRAY_API_KEY -H "X-Bintray-Package:$PCK_NAME" -H "X-Bintray-Version:$version_date" -H "X-Bintray-Publish:1" -H "X-Bintray-Override:1" https://api.bintray.com/content/$BINTRAY_USER/$BINTRAY_REPO/lnx-nightly-$version_date.zip
|
|
||||||
echo "files uploaded!"
|
|
||||||
|
|
||||||
# update the latest commit on bintray
|
|
||||||
echo "updating commit record on bintray..."
|
|
||||||
echo $local_commit > commit.txt
|
|
||||||
curl -T commit.txt -u$BINTRAY_USER:$BINTRAY_API_KEY -H "X-Bintray-Package:commit" -H "X-Bintray-Version:latest" -H "X-Bintray-Publish:1" -H "X-Bintray-Override:1" https://api.bintray.com/content/$BINTRAY_USER/$BINTRAY_REPO/commit.txt
|
|
||||||
rm -f commit.txt
|
|
||||||
echo "commit record updated!"
|
|
||||||
else
|
|
||||||
echo "error creating version $version_date !"
|
|
||||||
exit 2
|
|
||||||
fi
|
|
||||||
# try to trigger a new build in OBS
|
|
||||||
obs_trigger=$(curl --user $OBS_USER:$OBS_SECRET --write-out %{http_code} --silent --output /dev/null -H 'Accept-Encoding: identity' -H 'User-agent: osc/0.164.2' -H 'Content-type: application/x-www-form-urlencoded' -X POST https://api.opensuse.org/build/home:justdan96?cmd=rebuild&package=tsMuxer)
|
|
||||||
echo $obs_trigger
|
|
||||||
#if [ $obs_trigger -eq 200 ] ; then
|
|
||||||
# echo "build has been triggered in OBS!"
|
|
||||||
#else
|
|
||||||
# echo "error triggering build in OBS!"
|
|
||||||
# exit 3
|
|
||||||
#fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# upload the ZIP files to the version we just created on bintray
|
||||||
|
echo "uploading files..."
|
||||||
|
for buildname in w32 w64 lnx; do
|
||||||
|
upload_to_bintray "./bin/${buildname}.zip" "$buildname"
|
||||||
|
done
|
||||||
|
echo "files uploaded!"
|
||||||
|
|
||||||
|
# update the latest commit on bintray
|
||||||
|
echo "updating commit record on bintray..."
|
||||||
|
git rev-parse HEAD | curl -T - "-u$BINTRAY_USER:$BINTRAY_API_KEY" -H "X-Bintray-Package:commit" -H "X-Bintray-Version:latest" -H "X-Bintray-Publish:1" -H "X-Bintray-Override:1" "https://api.bintray.com/content/$BINTRAY_USER/$BINTRAY_REPO/commit.txt"0
|
||||||
|
echo "commit record updated!"
|
||||||
|
|
||||||
|
# try to trigger a new build in OBS
|
||||||
|
obs_trigger=$(curl --user $OBS_USER:$OBS_SECRET --write-out %{http_code} --silent --output /dev/null -H 'Accept-Encoding: identity' -H 'User-agent: osc/0.164.2' -H 'Content-type: application/x-www-form-urlencoded' -X POST https://api.opensuse.org/build/home:justdan96?cmd=rebuild&package=tsMuxer)
|
||||||
|
echo $obs_trigger
|
||||||
|
#if [ $obs_trigger -eq 200 ] ; then
|
||||||
|
# echo "build has been triggered in OBS!"
|
||||||
|
#else
|
||||||
|
# echo "error triggering build in OBS!"
|
||||||
|
# exit 3
|
||||||
|
#fi
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
set -x
|
set -x
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
export MACOSX_DEPLOYMENT_TARGET=10.10
|
export MACOSX_DEPLOYMENT_TARGET=10.13
|
||||||
|
|
||||||
brew install pkg-config
|
brew install pkg-config
|
||||||
brew install freetype
|
brew install freetype
|
||||||
@ -31,6 +31,6 @@ pushd bin
|
|||||||
mv ../tsMuxer/tsmuxer tsMuxeR
|
mv ../tsMuxer/tsmuxer tsMuxeR
|
||||||
mv ../tsMuxerGUI/tsMuxerGUI.app .
|
mv ../tsMuxerGUI/tsMuxerGUI.app .
|
||||||
cp tsMuxeR tsMuxerGUI.app/Contents/MacOS/
|
cp tsMuxeR tsMuxerGUI.app/Contents/MacOS/
|
||||||
BZIP2=-9 tar cjf mac.tar.bz2 tsMuxeR tsMuxerGUI.app
|
zip -9 -r mac.zip tsMuxeR tsMuxerGUI.app
|
||||||
popd
|
popd
|
||||||
popd
|
popd
|
||||||
|
Loading…
x
Reference in New Issue
Block a user