The command is:
/opt/reyboz/android/bin/publish-latest-branch-build.sh ${buildable.revision}
Source code:
This step will copy the built .apk to an indexed HTTP directory exposed by Apache:
Passed |
The command is:
/opt/reyboz/android/bin/publish-latest-branch-build.sh ${buildable.revision}
Source code:
This step will copy the built .apk to an indexed HTTP directory exposed by Apache:
1 | [INFO] including .env file |
---|---|
2 | Current directory: |
3 | /var/drydock/workingcopy-112/repo/libre-busto |
4 | Calculating sha256sum of: |
5 | ./app/build/outputs/apk/gitpull/app-gitpull-signed.apk |
6 | File info |
7 | -rw-r--r-- 1 phabricator-android-builder phabricator-android-builder 25116710 Nov 8 20:45 ./app/build/outputs/apk/gitpull/app-gitpull-signed.apk |
8 | Cleaning old builds |
9 | Update checksums |
10 | Published here: |
11 | https://lab.reyboz.it/builds/libre-busto/maplibre-libre-busto.apk |
12 | Cleaning |
13 | Done |
14 |
Passed |
This script is available here on gargantua.reyboz.it accessible to the Unix user phabricator-android-builder:
/opt/reyboz/android/bin/align-sign-fabione.sh
In general it does that:
#!/bin/sh # https://gitpull.it/harbormaster/step/view/16/ BASEDIR="app/build/outputs/apk/gitpull" OUT="app-gitpull-signed.apk" APK_UNSIGNED="app-gitpull-unsigned.apk" APK_ALIGNED="app-gitpull-unsigned-aligned.apk" KEYSTORE="/home/phabricator-android-builder/private-resources/gitpullkeystore-libre-busto.jks" PASSPHRASE="<omissis> echo "Entering in $BASEDIR" cd "$BASEDIR" echo "Aligning zip" ~/bin/zipalign -v -p 4 "$APK_UNSIGNED" "$APK_ALIGNED" echo "Signing APK" # NOTE: keep keystore unsescaped ~/bin/apksigner sign --ks "$KEYSTORE" --out "$OUT" --ks-pass pass:"$PASSPHRASE" "$APK_ALIGNED" echo "Sign concluded with exit status $?"
1251 | 23594014 res/xQ.xml (OK - compressed) |
---|---|
1252 | 23594504 res/xR.9.png (OK) |
1253 | 23594740 res/xa.9.png (OK) |
1254 | 23595001 res/xa.xml (OK - compressed) |
1255 | 23595562 res/xd.xml (OK - compressed) |
1256 | 23596275 res/xj.xml (OK - compressed) |
1257 | 23596567 res/xo.xml (OK - compressed) |
1258 | 23596854 res/xq.xml (OK - compressed) |
1259 | 23597241 res/xz.xml (OK - compressed) |
1260 | 23598432 res/y-.xml (OK - compressed) |
1261 | 23598700 res/y3.png (OK) |
1262 | 23606402 res/y4.xml (OK - compressed) |
1263 | 23606658 res/y9.xml (OK - compressed) |
1264 | 23606926 res/yE.xml (OK - compressed) |
1265 | 23607184 res/yH.9.png (OK) |
1266 | 23607408 res/yO.xml (OK - compressed) |
1267 | 23607658 res/yT.xml (OK - compressed) |
1268 | 23607980 res/yV.xml (OK - compressed) |
1269 | 23608320 res/yY.9.png (OK) |
1270 | 23608546 res/yY.xml (OK - compressed) |
1271 | 23608832 res/ya.xml (OK - compressed) |
1272 | 23609192 res/yd.png (OK) |
1273 | 23621128 res/ye.png (OK) |
1274 | 23622324 res/yg.9.png (OK) |
1275 | 23622759 res/yj.xml (OK - compressed) |
1276 | 23623156 res/yn.png (OK) |
1277 | 23625640 res/z-.9.png (OK) |
1278 | 23625904 res/z9.9.png (OK) |
1279 | 23626364 res/zE.png (OK) |
1280 | 23626728 res/zG.xml (OK - compressed) |
1281 | 23627048 res/zL.png (OK) |
1282 | 23627296 res/zP.png (OK) |
1283 | 23645256 res/zR.png (OK) |
1284 | 23648057 res/zR.xml (OK - compressed) |
1285 | 23648544 res/zV.9.png (OK) |
1286 | 23651048 res/zZ.png (OK) |
1287 | 23657743 res/zc.xml (OK - compressed) |
1288 | 23658192 res/ze.png (OK) |
1289 | 23666547 res/zp.xml (OK - compressed) |
1290 | 23666805 res/zq.xml (OK - compressed) |
1291 | 23667116 res/zr.png (OK) |
1292 | 23669935 res/zs.xml (OK - compressed) |
1293 | 23670207 res/zu.xml (OK - compressed) |
1294 | 23671240 res/zz.png (OK) |
1295 | 23672164 res/zz.xml (OK - compressed) |
1296 | 23672356 resources.arsc (OK) |
1297 | Verification succesful |
1298 | Signing APK |
1299 | Sign concluded with exit status 0 |
1300 |
Passed |
This step will build an .apk using Gradle.
sudo apt install openjdk-11-jre-headless
Then aliased this gradle:
https://gitlab.com/fdroid/fdroidserver/-/blob/master/gradlew-fdroid
1 | Note: Some input files use or override a deprecated API. |
---|---|
2 | Note: Recompile with -Xlint:deprecation for details. |
3 | /var/drydock/workingcopy-112/repo/libre-busto/app/src/gitpull/AndroidManifest.xml:4: Error: Mock locations should only be requested in a test or debug-specific manifest file (typically src/debug/AndroidManifest.xml) [MockLocation] |
4 | <uses-permission android:name="android.permission.ACCESS_MOCK_LOCATION"/> |
5 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
6 | |
7 | Explanation for issues of type "MockLocation": |
8 | Using a mock location provider (by requiring the permission |
9 | android.permission.ACCESS_MOCK_LOCATION) should only be done in debug |
10 | builds (or from tests). In Gradle projects, that means you should only |
11 | request this permission in a test or debug source set specific manifest |
12 | file. |
13 | |
14 | To fix this, create a new manifest file in the debug folder and move the |
15 | <uses-permission> element there. A typical path to a debug manifest |
16 | override file in a Gradle project is src/debug/AndroidManifest.xml. |
17 | |
18 | 1 errors, 0 warnings |
19 | |
20 |
109 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/fragments/MapFragmentKt.kt:613:74 Parameter 'pattern' is never used, could be renamed to _ |
---|---|
110 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/fragments/MapFragmentKt.kt:648:21 Unnecessary non-null assertion (!!) on a non-null receiver of type MapView |
111 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/fragments/MapFragmentKt.kt:655:27 Unnecessary non-null assertion (!!) on a non-null receiver of type MapView |
112 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/fragments/MapFragmentKt.kt:660:31 Unnecessary non-null assertion (!!) on a non-null receiver of type FolderOverlay |
113 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/fragments/MapFragmentKt.kt:661:21 Unnecessary non-null assertion (!!) on a non-null receiver of type MapView |
114 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/fragments/MapFragmentKt.kt:668:12 Unnecessary non-null assertion (!!) on a non-null receiver of type MapView |
115 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/fragments/MapFragmentKt.kt:695:63 Parameter 'mapView' is never used, could be renamed to _ |
116 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/fragments/MapFragmentKt.kt:707:20 Unnecessary non-null assertion (!!) on a non-null receiver of type MapView |
117 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/fragments/TestRealtimeGtfsFragment.kt:84:27 Parameter 'cont' is never used, could be renamed to _ |
118 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/map/BusInfoWindow.kt:45:36 Parameter 'view' is never used, could be renamed to _ |
119 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/map/BusInfoWindow.kt:45:42 Parameter 'motionEvent' is never used, could be renamed to _ |
120 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/map/BusInfoWindow.kt:88:17 Variable 'layPars' is never used |
121 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:185:27 'LocationProvider' is deprecated. Deprecated in Java |
122 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:185:44 'OUT_OF_SERVICE: Int' is deprecated. Deprecated in Java |
123 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:185:72 'LocationProvider' is deprecated. Deprecated in Java |
124 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:185:89 'TEMPORARILY_UNAVAILABLE: Int' is deprecated. Deprecated in Java |
125 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:187:34 'LocationProvider' is deprecated. Deprecated in Java |
126 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:187:51 'AVAILABLE: Int' is deprecated. Deprecated in Java |
127 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:215:48 'Criteria' is deprecated. Deprecated in Java |
128 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/util/ImportExport.kt:50:43 Variable 'map' initializer is redundant |
129 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/util/ImportExport.kt:53:40 Unchecked cast: Any! to Map<String?, Any>? |
130 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/util/ImportExport.kt:71:51 No cast needed |
131 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/util/ImportExport.kt:73:49 No cast needed |
132 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/util/ImportExport.kt:75:46 No cast needed |
133 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/util/ImportExport.kt:77:48 No cast needed |
134 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/util/ImportExport.kt:79:48 No cast needed |
135 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/util/ImportExport.kt:81:42 No cast needed |
136 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/util/ImportExport.kt:83:56 Unchecked cast: Any to Set<String?> |
137 | w: file:///var/drydock/workingcopy-112/repo/libre-busto/app/src/main/java/it/reyboz/bustorino/viewmodels/LivePositionsViewModel.kt:271:29 Parameter 'req' is never used, could be renamed to _ |
138 | |
139 | > Task :app:compileGitpullJavaWithJavac |
140 | |
141 | > Task :app:dexBuilderGitpull |
142 | > Task :app:mergeGitpullGlobalSynthetics |
143 | > Task :app:processGitpullJavaRes |
144 | > Task :app:mergeGitpullJavaResource |
145 | > Task :app:mergeDexGitpull |
146 | > Task :app:compileGitpullArtProfile |
147 | > Task :app:packageGitpull |
148 | > Task :app:createGitpullApkListingFileRedirect |
149 | > Task :app:lintVitalAnalyzeGitpull |
150 | > Task :app:lintVitalReportGitpull |
151 | |
152 | > Task :app:lintVitalGitpull |
153 | |
154 | > Task :app:assembleGitpull |
155 | |
156 | BUILD SUCCESSFUL in 1m 44s |
157 | 45 actionable tasks: 45 executed |
158 |
Passed |
Clean Gradle directory to avoid nasty errors like:
1 | Found 8.1 via distributionUrl |
---|---|
2 | Running /home/phabricator-android-builder/versions/8.1/bin/gradle clean |
3 | > Task :app:clean |
4 | |
5 | BUILD SUCCESSFUL in 2s |
6 | 1 actionable task: 1 executed |
7 |
Passed |
Passed |