@@ -35,7 +35,7 @@ script:
35
35
if [ "$TRAVIS_TEST_RESULT" -eq 0 ]
36
36
then
37
37
CURR=$(tail -n1 sizes | awk '{print $1}')
38
- PREV=$(curl -u $GEKY_BOT_STATUSES https://api.github.com/repos/$TRAVIS_REPO_SLUG/status/master \
38
+ PREV=$(curl -u " $GEKY_BOT_STATUSES" https://api.github.com/repos/$TRAVIS_REPO_SLUG/status/master \
39
39
| jq -re "select(.sha != \"$TRAVIS_COMMIT\")
40
40
| .statuses[] | select(.context == \"$STAGE/$NAME\").description
41
41
| capture(\"code size is (?<size>[0-9]+)\").size" \
@@ -100,6 +100,7 @@ jobs:
100
100
env :
101
101
- STAGE=test
102
102
- NAME=littlefs-fuse
103
+ if : branch !~ -prefix$
103
104
install :
104
105
- sudo apt-get install libfuse-dev
105
106
- git clone --depth 1 https://github.com/geky/littlefs-fuse
@@ -128,56 +129,88 @@ jobs:
128
129
- ls
129
130
- make -B test_dirs test_files QUIET=1
130
131
131
- # Automatically update releases
132
+ # Automatically create releases
132
133
- stage : deploy
133
134
env :
134
135
- STAGE=deploy
135
136
- NAME=deploy
136
137
script :
137
- # Find version defined in lfs.h
138
- - LFS_VERSION=$(grep -ox '#define LFS_VERSION .*' lfs.h | cut -d ' ' -f3)
139
- - LFS_VERSION_MAJOR=$((0xffff & ($LFS_VERSION >> 16)))
140
- - LFS_VERSION_MINOR=$((0xffff & ($LFS_VERSION >> 0)))
141
- # Grab latests patch from repo tags, default to 0
142
- - LFS_VERSION_PATCH=$(curl -f -u "$GEKY_BOT_RELEASES"
143
- https://api.github.com/repos/$TRAVIS_REPO_SLUG/git/refs
144
- | jq 'map(.ref | match(
145
- " refs/tags/v'" $LFS_VERSION_MAJOR"'\\.'"$LFS_VERSION_MINOR"'\\.(.*)$")
146
- .captures[].string | tonumber + 1) | max // 0')
147
- # We have our new version
148
- - LFS_VERSION="v$LFS_VERSION_MAJOR.$LFS_VERSION_MINOR.$LFS_VERSION_PATCH"
149
- - echo "VERSION $LFS_VERSION"
150
138
- |
139
+ bash << 'SCRIPT'
140
+ set -ev
141
+ # Find version defined in lfs.h
142
+ LFS_VERSION=$(grep -ox '#define LFS_VERSION .*' lfs.h | cut -d ' ' -f3)
143
+ LFS_VERSION_MAJOR=$((0xffff & ($LFS_VERSION >> 16)))
144
+ LFS_VERSION_MINOR=$((0xffff & ($LFS_VERSION >> 0)))
145
+ # Grab latests patch from repo tags, default to 0, needs finagling
146
+ # to get past github's pagination api
147
+ PREV_URL=https://api.github.com/repos/$TRAVIS_REPO_SLUG/git/refs/tags/v$LFS_VERSION_MAJOR.$LFS_VERSION_MINOR.
148
+ PREV_URL=$(curl -u "$GEKY_BOT_RELEASES" "$PREV_URL" -I \
149
+ | sed -n '/^Link/{s/.*<\(.*\)>; rel="last"/\1/;p;q0};$q1' \
150
+ || echo $PREV_URL)
151
+ LFS_VERSION_PATCH=$(curl -u "$GEKY_BOT_RELEASES" "$PREV_URL" \
152
+ | jq 'map(.ref | match("\\bv.*\\..*\\.(.*)$";"g")
153
+ .captures[].string | tonumber) | max + 1' \
154
+ || echo 0)
155
+ # We have our new version
156
+ LFS_VERSION="v$LFS_VERSION_MAJOR.$LFS_VERSION_MINOR.$LFS_VERSION_PATCH"
157
+ echo "VERSION $LFS_VERSION"
151
158
# Check that we're the most recent commit
152
159
CURRENT_COMMIT=$(curl -f -u "$GEKY_BOT_RELEASES" \
153
- https://api.github.com/repos/$TRAVIS_REPO_SLUG/commits/master \
154
- | jq -re '.sha')
155
- if [ "$TRAVIS_COMMIT" == "$CURRENT_COMMIT" ]
160
+ https://api.github.com/repos/$TRAVIS_REPO_SLUG/commits/master \
161
+ | jq -re '.sha')
162
+ [ "$TRAVIS_COMMIT" == "$CURRENT_COMMIT" ] || exit 0
163
+ # Create major branch
164
+ git branch v$LFS_VERSION_MAJOR HEAD
165
+ # Create major prefix branch
166
+ git config user.name "geky bot"
167
+ git config user.email "[email protected] "
168
+ git fetch https://github.com/$TRAVIS_REPO_SLUG.git \
169
+ --depth=50 v$LFS_VERSION_MAJOR-prefix || true
170
+ ./scripts/prefix.py lfs$LFS_VERSION_MAJOR
171
+ git branch v$LFS_VERSION_MAJOR-prefix $( \
172
+ git commit-tree $(git write-tree) \
173
+ $(git rev-parse --verify -q FETCH_HEAD | sed -e 's/^/-p /') \
174
+ -p HEAD \
175
+ -m "Generated v$LFS_VERSION_MAJOR prefixes")
176
+ git reset --hard
177
+ # Update major version branches (vN and vN-prefix)
178
+ git push https://[email protected] /$TRAVIS_REPO_SLUG.git \
179
+ v$LFS_VERSION_MAJOR \
180
+ v$LFS_VERSION_MAJOR-prefix
181
+ # Create patch version tag (vN.N.N)
182
+ curl -f -u "$GEKY_BOT_RELEASES" -X POST \
183
+ https://api.github.com/repos/$TRAVIS_REPO_SLUG/git/refs \
184
+ -d "{
185
+ \"ref\": \"refs/tags/$LFS_VERSION\",
186
+ \"sha\": \"$TRAVIS_COMMIT\"
187
+ }"
188
+ # Create minor release?
189
+ [[ "$LFS_VERSION" == *.0 ]] || exit 0
190
+ # Build release notes
191
+ PREV=$(git tag --sort=-v:refname -l "v*.0" | head -1)
192
+ if [ ! -z "$PREV" ]
156
193
then
157
- # Build release notes
158
- PREV=$(git tag --sort=-v:refname -l "v*" | head -1)
159
- if [ ! -z "$PREV" ]
160
- then
161
- echo "PREV $PREV"
162
- CHANGES=$'### Changes\n\n'$( \
163
- git log --oneline $PREV.. --grep='^Merge' --invert-grep)
164
- printf "CHANGES\n%s\n\n" "$CHANGES"
165
- fi
166
- # Create the release
167
- curl -f -u "$GEKY_BOT_RELEASES" -X POST \
168
- https://api.github.com/repos/$TRAVIS_REPO_SLUG/releases \
169
- -d "{
170
- \"tag_name\": \"$LFS_VERSION\",
171
- \"target_commitish\": \"$TRAVIS_COMMIT\",
172
- \"name\": \"${LFS_VERSION%.0}\",
173
- \"body\": $(jq -sR '.' <<< "$CHANGES")
174
- }"
194
+ echo "PREV $PREV"
195
+ CHANGES=$'### Changes\n\n'$( \
196
+ git log --oneline $PREV.. --grep='^Merge' --invert-grep)
197
+ printf "CHANGES\n%s\n\n" "$CHANGES"
175
198
fi
199
+ # Create the release
200
+ curl -f -u "$GEKY_BOT_RELEASES" -X POST \
201
+ https://api.github.com/repos/$TRAVIS_REPO_SLUG/releases \
202
+ -d "{
203
+ \"tag_name\": \"$LFS_VERSION\",
204
+ \"name\": \"${LFS_VERSION%.0}\",
205
+ \"draft\": true,
206
+ \"body\": $(jq -sR '.' <<< "$CHANGES")
207
+ }" #"
208
+ SCRIPT
176
209
177
210
# Manage statuses
178
211
before_install :
179
212
- |
180
- curl -u $GEKY_BOT_STATUSES -X POST \
213
+ curl -u " $GEKY_BOT_STATUSES" -X POST \
181
214
https://api.github.com/repos/$TRAVIS_REPO_SLUG/statuses/${TRAVIS_PULL_REQUEST_SHA:-$TRAVIS_COMMIT} \
182
215
-d "{
183
216
\"context\": \"$STAGE/$NAME\",
@@ -188,7 +221,7 @@ before_install:
188
221
189
222
after_failure :
190
223
- |
191
- curl -u $GEKY_BOT_STATUSES -X POST \
224
+ curl -u " $GEKY_BOT_STATUSES" -X POST \
192
225
https://api.github.com/repos/$TRAVIS_REPO_SLUG/statuses/${TRAVIS_PULL_REQUEST_SHA:-$TRAVIS_COMMIT} \
193
226
-d "{
194
227
\"context\": \"$STAGE/$NAME\",
@@ -199,7 +232,7 @@ after_failure:
199
232
200
233
after_success :
201
234
- |
202
- curl -u $GEKY_BOT_STATUSES -X POST \
235
+ curl -u " $GEKY_BOT_STATUSES" -X POST \
203
236
https://api.github.com/repos/$TRAVIS_REPO_SLUG/statuses/${TRAVIS_PULL_REQUEST_SHA:-$TRAVIS_COMMIT} \
204
237
-d "{
205
238
\"context\": \"$STAGE/$NAME\",
0 commit comments