Source code:
https://gitpull.it/source/libre-busto-ci-cd/browse/master/bin/publish-latest-branch-build.sh
(ex P23)
This step will copy the built .apk to an indexed HTTP directory exposed by Apache, signing them:
| Passed |
Source code:
https://gitpull.it/source/libre-busto-ci-cd/browse/master/bin/publish-latest-branch-build.sh
(ex P23)
This step will copy the built .apk to an indexed HTTP directory exposed by Apache, signing them:
| 5832 | 24767880 res/v4.9.png (OK) |
|---|---|
| 5833 | 24768128 res/v5.xml (OK - compressed) |
| 5834 | 24768452 res/vF.xml (OK - compressed) |
| 5835 | 24768711 res/vG.xml (OK - compressed) |
| 5836 | 24769348 res/vH.xml (OK - compressed) |
| 5837 | 24769681 res/vJ.xml (OK - compressed) |
| 5838 | 24770008 res/vL.9.png (OK) |
| 5839 | 24770271 res/vR.xml (OK - compressed) |
| 5840 | 24770536 res/vT.xml (OK - compressed) |
| 5841 | 24770764 res/vZ.xml (OK - compressed) |
| 5842 | 24771021 res/vf.xml (OK - compressed) |
| 5843 | 24771348 res/vl.xml (OK - compressed) |
| 5844 | 24771919 res/vn.xml (OK - compressed) |
| 5845 | 24772272 res/vq.xml (OK - compressed) |
| 5846 | 24772850 res/vy.xml (OK - compressed) |
| 5847 | 24773340 res/vz.9.png (OK) |
| 5848 | 24773561 res/w7.xml (OK - compressed) |
| 5849 | 24774317 res/w9.xml (OK - compressed) |
| 5850 | 24774592 res/wL.9.png (OK) |
| 5851 | 24775072 res/wN.9.png (OK) |
| 5852 | 24775337 res/wP.xml (OK - compressed) |
| 5853 | 24775692 res/w_.png (OK) |
| 5854 | 24775948 res/wb.png (OK) |
| 5855 | 24781877 res/wi.xml (OK - compressed) |
| 5856 | 24782252 res/wy.png (OK) |
| 5857 | 24782720 res/x3.9.png (OK) |
| 5858 | 24782972 res/x4.xml (OK - compressed) |
| 5859 | 24783748 res/xH.png (OK) |
| 5860 | 24783974 res/xI.xml (OK - compressed) |
| 5861 | 24784675 res/xM.ttf (OK - compressed) |
| 5862 | 24844368 res/xR.9.png (OK) |
| 5863 | 24844604 res/xa.9.png (OK) |
| 5864 | 24844865 res/xa.xml (OK - compressed) |
| 5865 | 24845426 res/xd.xml (OK - compressed) |
| 5866 | 24846139 res/xj.xml (OK - compressed) |
| 5867 | 24846431 res/xq.xml (OK - compressed) |
| 5868 | 24846819 res/xz.xml (OK - compressed) |
| 5869 | 24848010 res/y-.xml (OK - compressed) |
| 5870 | 24848278 res/y4.xml (OK - compressed) |
| 5871 | 24848534 res/y9.xml (OK - compressed) |
| 5872 | 24848803 res/yE.xml (OK - compressed) |
| 5873 | 24849060 res/yH.9.png (OK) |
| 5874 | 24849284 res/yS.xml (OK - compressed) |
| 5875 | 24849535 res/yT.xml (OK - compressed) |
| 5876 | 24849858 res/yV.xml (OK - compressed) |
| 5877 | 24850200 res/yY.9.png (OK) |
| 5878 | 24850426 res/ya.xml (OK - compressed) |
| 5879 | 24850784 res/yd.png (OK) |
| 5880 | 24862720 res/yg.9.png (OK) |
| 5881 | 24863155 res/yj.xml (OK - compressed) |
| 5882 | 24863552 res/yn.png (OK) |
| 5883 | 24866036 res/z-.9.png (OK) |
| 5884 | 24866300 res/z9.9.png (OK) |
| 5885 | 24866760 res/zE.png (OK) |
| 5886 | 24867124 res/zG.xml (OK - compressed) |
| 5887 | 24867444 res/zR.png (OK) |
| 5888 | 24870245 res/zR.xml (OK - compressed) |
| 5889 | 24870736 res/zV.9.png (OK) |
| 5890 | 24873239 res/zc.xml (OK - compressed) |
| 5891 | 24873692 res/ze.png (OK) |
| 5892 | 24882047 res/zp.xml (OK - compressed) |
| 5893 | 24882306 res/zq.xml (OK - compressed) |
| 5894 | 24882616 res/zr.png (OK) |
| 5895 | 24885435 res/zs.xml (OK - compressed) |
| 5896 | 24885707 res/zu.xml (OK - compressed) |
| 5897 | 24886685 res/zv.xml (OK - compressed) |
| 5898 | 24887968 resources.arsc (OK) |
| 5899 | Verification succesful |
| 5900 | [INFO][2026-04-24 21:51:04] APK ALIGNED D226-x86_64-aligned.apk: apksigner... creating D226-x86_64-signed.apk |
| 5901 | [INFO][2026-04-24 21:51:05] APK ALIGNED SIGNED D226-x86_64-signed.apk: calculating sha256sum... |
| 5902 | DEBUG TELEGRAM CONTENT |
| 5903 | ⚙ Dear Android hackers, please review this promising patch: |
| 5904 | https://gitpull\.it/D226 |
| 5905 | |
| 5906 | Here the related fresh test builds: |
| 5907 | |
| 5908 | APK for **arm64\-v8a**: |
| 5909 | [Download D226\-arm64\-v8a\-signed\.apk](https://lab.reyboz.it/builds/libre-busto/D226-arm64-v8a-signed.apk) |
| 5910 | APK sha256: `f8a5958217d55d1734bb4d9bc33729e3c56415df9c08ec41f7d9e6b9261de562` |
| 5911 | |
| 5912 | APK for **armeabi\-v7a**: |
| 5913 | [Download D226\-armeabi\-v7a\-signed\.apk](https://lab.reyboz.it/builds/libre-busto/D226-armeabi-v7a-signed.apk) |
| 5914 | APK sha256: `a09497c8cdb301c37c6cad0102a7e5e02d25b48ee94e72472483c0d297079d39` |
| 5915 | |
| 5916 | APK for **universal**: |
| 5917 | [Download D226\-universal\-signed\.apk](https://lab.reyboz.it/builds/libre-busto/D226-universal-signed.apk) |
| 5918 | APK sha256: `486238810735d996c150d1873bd887e7c468b4a454275ad002e32aaf630dbb40` |
| 5919 | |
| 5920 | APK for **x86**: |
| 5921 | [Download D226\-x86\-signed\.apk](https://lab.reyboz.it/builds/libre-busto/D226-x86-signed.apk) |
| 5922 | APK sha256: `2cff1c176c24b8f0b05ccd9cd91afe32eae7cc82f53113b0d49aac3ac41bf296` |
| 5923 | |
| 5924 | APK for **x86\_64**: |
| 5925 | [Download D226\-x86\_64\-signed\.apk](https://lab.reyboz.it/builds/libre-busto/D226-x86_64-signed.apk) |
| 5926 | APK sha256: `7bc7d88ef38e18f3b792b263cb98abc93752e359a36d33f596db55ab37ea27c7` |
| 5927 | |
| 5928 | Adding bipbop Comment to D226 |
| 5929 | [INFO][2026-04-24 21:51:06] Cleaning old artifacts |
| 5930 | [INFO][2026-04-24 21:51:06] Done |
| 5931 |
| Passed |
This step will build an .apk using Gradle using this fantastic Docker image:
https://gitlab.com/fabmazz/android-fdroid-build-container/-/tree/ubuntu
Source code of this build step:
https://gitpull.it/source/libre-busto-ci-cd/browse/master/bin/fdroid-docker-builder.sh
TODO: Use the official image by Fabio Mazza, when the "DESIRED_UID" / "DESIRED_GID" features will be merged.
| 1 | + docker run -e DESIRED_UID=1004 -e DESIRED_GID=1004 --rm -v /var/drydock/workingcopy-79/repo/libre-busto:/home/vagrant/appbuild:Z fdroid-asder launch_build_local -Dorg.gradle.jvmargs=-Xmx2g --stacktrace assembleGitpull |
|---|---|
| 2 | Note: Some input files use or override a deprecated API. |
| 3 | Note: Recompile with -Xlint:deprecation for details. |
| 4 | /home/vagrant/appbuild/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] |
| 5 | <uses-permission android:name="android.permission.ACCESS_MOCK_LOCATION"/> |
| 6 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
| 7 | |
| 8 | Explanation for issues of type "MockLocation": |
| 9 | Using a mock location provider (by requiring the permission |
| 10 | android.permission.ACCESS_MOCK_LOCATION) should only be done in debug |
| 11 | builds (or from tests). In Gradle projects, that means you should only |
| 12 | request this permission in a test or debug source set specific manifest |
| 13 | file. |
| 14 | |
| 15 | To fix this, create a new manifest file in the debug folder and move the |
| 16 | <uses-permission> element there. A typical path to a debug manifest |
| 17 | override file in a Gradle project is src/debug/AndroidManifest.xml. |
| 18 | |
| 19 | 1 error |
| 20 | |
| 21 |
| 69 | > Task :app:processGitpullNavigationResources |
|---|---|
| 70 | > Task :app:generateGitpullResValues |
| 71 | > Task :app:compileGitpullNavigationResources |
| 72 | > Task :app:mapGitpullSourceSetPaths |
| 73 | > Task :app:extractGitpullSupportedLocales |
| 74 | > Task :app:generateGitpullLocaleConfig |
| 75 | > Task :app:generateGitpullResources |
| 76 | > Task :app:createGitpullCompatibleScreenManifests |
| 77 | > Task :app:extractDeepLinksGitpull |
| 78 | |
| 79 | > Task :app:processGitpullMainManifest |
| 80 | /home/vagrant/appbuild/app/src/gitpull/AndroidManifest.xml Warning: |
| 81 | service#info.mqtt.android.service.MqttService was tagged at AndroidManifest.xml:0 to replace another declaration but no other declaration present |
| 82 | /home/vagrant/appbuild/app/src/gitpull/AndroidManifest.xml Warning: |
| 83 | provider#org.acra.attachment.AcraContentProvider@android:authorities was tagged at AndroidManifest.xml:0 to replace other declarations but no other declaration present |
| 84 | |
| 85 | > Task :app:processGitpullManifest |
| 86 | > Task :app:mergeGitpullResources |
| 87 | > Task :app:desugarGitpullFileDependencies |
| 88 | > Task :app:mergeGitpullStartupProfile |
| 89 | > Task :app:javaPreCompileGitpull |
| 90 | > Task :app:processGitpullManifestForPackage |
| 91 | > Task :app:mergeExtDexGitpull |
| 92 | > Task :app:mergeGitpullShaders |
| 93 | > Task :app:compileGitpullShaders NO-SOURCE |
| 94 | > Task :app:generateGitpullAssets UP-TO-DATE |
| 95 | > Task :app:mergeGitpullArtProfile |
| 96 | > Task :app:mergeGitpullAssets |
| 97 | > Task :app:compressGitpullAssets |
| 98 | > Task :app:extractGitpullVersionControlInfo |
| 99 | > Task :app:extractProguardFiles |
| 100 | > Task :app:collectGitpullDependencies |
| 101 | > Task :app:sdkGitpullDependencyData |
| 102 | > Task :app:writeGitpullAppMetadata |
| 103 | > Task :app:writeGitpullSigningConfigVersions |
| 104 | > Task :app:processGitpullResources |
| 105 | > Task :app:optimizeGitpullResources |
| 106 | |
| 107 | > Task :app:kspGitpullKotlin |
| 108 | w: [ksp] /home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/data/gtfs/GtfsAgency.kt:21: Primary key constraint on gtfsId is ignored when being merged into it.reyboz.bustorino.data.gtfs.GtfsAgency |
| 109 | |
| 110 | > Task :app:compileGitpullKotlin |
| 111 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/ActivityAbout.kt:132:13 'fun onBackPressed(): Unit' is deprecated. This method has been deprecated in favor of using the |
| 112 | {@link OnBackPressedDispatcher} via {@link #getOnBackPressedDispatcher()}. |
| 113 | The OnBackPressedDispatcher controls how back button events are dispatched |
| 114 | to one or more {@link OnBackPressedCallback} objects. |
| 115 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/ArrivalsFragment.kt:142:21 'val loaderManager: LoaderManager' is deprecated. Deprecated in Java. |
| 116 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/ArrivalsFragment.kt:147:30 'val loaderManager: LoaderManager' is deprecated. Deprecated in Java. |
| 117 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/ArrivalsFragment.kt:374:29 'val loaderManager: LoaderManager' is deprecated. Deprecated in Java. |
| 118 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/ArrivalsFragment.kt:427:29 'val loaderManager: LoaderManager' is deprecated. Deprecated in Java. |
| 119 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/ArrivalsFragment.kt:582:20 Condition is always 'true'. |
| 120 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/ArrivalsFragment.kt:697:66 'fun execute(vararg p0: Stop!): AsyncTask<Stop!, Void!, Boolean!>!' is deprecated. Deprecated in Java. |
| 121 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/IntroFragment.kt:172:43 'fun setColorFilter(p0: Int, p1: PorterDuff.Mode): Unit' is deprecated. Deprecated in Java. |
| 122 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/IntroFragment.kt:213:24 'fun setColorFilter(p0: Int, p1: PorterDuff.Mode): Unit' is deprecated. Deprecated in Java. |
| 123 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/LinesDetailFragment.kt:186:21 Condition is always 'false'. |
| 124 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/MapLibreFragment.kt:650:25 'fun requestSingleUpdate(p0: String, p1: LocationListener, p2: Looper?): Unit' is deprecated. Deprecated in Java. |
| 125 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/MapLibreFragment.kt:671:26 This declaration overrides a deprecated member but is not marked as deprecated itself. Add the '@Deprecated' annotation or suppress the diagnostic. |
| 126 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/fragments/TestRealtimeGtfsFragment.kt:55:39 The corresponding parameter in the supertype 'MQTTMatoListener' is named 'posUpdates'. This may cause problems when calling this function with named arguments. |
| 127 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:186:27 'class LocationProvider : Any' is deprecated. Deprecated in Java. |
| 128 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:186:44 'static field OUT_OF_SERVICE: Int' is deprecated. Deprecated in Java. |
| 129 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:186:72 'class LocationProvider : Any' is deprecated. Deprecated in Java. |
| 130 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:186:89 'static field TEMPORARILY_UNAVAILABLE: Int' is deprecated. Deprecated in Java. |
| 131 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:188:34 'class LocationProvider : Any' is deprecated. Deprecated in Java. |
| 132 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:188:51 'static field AVAILABLE: Int' is deprecated. Deprecated in Java. |
| 133 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/middleware/AppLocationManager.kt:216:48 'class Criteria : Any, Parcelable' is deprecated. Deprecated in Java. |
| 134 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/util/ImportExport.kt:53:40 Unchecked cast of 'Any!' to 'Map<String?, Any>?'. |
| 135 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/util/ImportExport.kt:83:56 Unchecked cast of 'Set<*>' to 'Set<String?>'. |
| 136 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/viewmodels/ArrivalsViewModel.kt:224:17 Expression under 'when' is never equal to null. |
| 137 | w: file:///home/vagrant/appbuild/app/src/main/java/it/reyboz/bustorino/viewmodels/LivePositionsViewModel.kt:145:39 The corresponding parameter in the supertype 'MQTTMatoListener' is named 'posUpdates'. This may cause problems when calling this function with named arguments. |
| 138 | |
| 139 | > Task :app:compileGitpullJavaWithJavac |
| 140 | |
| 141 | > Task :app:dexBuilderGitpull |
| 142 | > Task :app:mergeGitpullGlobalSynthetics |
| 143 | > Task :app:generateGitpullLintVitalReportModel |
| 144 | > Task :app:mergeDexGitpull |
| 145 | > Task :app:processGitpullJavaRes |
| 146 | > Task :app:compileGitpullArtProfile |
| 147 | > Task :app:mergeGitpullJavaResource |
| 148 | > Task :app:lintVitalAnalyzeGitpull |
| 149 | > Task :app:lintVitalReportGitpull |
| 150 | |
| 151 | > Task :app:lintVitalGitpull |
| 152 | |
| 153 | > Task :app:packageGitpull |
| 154 | > Task :app:createGitpullApkListingFileRedirect |
| 155 | > Task :app:assembleGitpull |
| 156 | |
| 157 | [Incubating] Problems report is available at: file:///home/vagrant/appbuild/build/reports/problems/problems-report.html |
| 158 | |
| 159 | Deprecated Gradle features were used in this build, making it incompatible with Gradle 9.0. |
| 160 | |
| 161 | You can use '--warning-mode all' to show the individual deprecation warnings and determine if they come from your own scripts or plugins. |
| 162 | |
| 163 | For more on this, please refer to https://docs.gradle.org/8.13/userguide/command_line_interface.html#sec:command_line_warnings in the Gradle documentation. |
| 164 | |
| 165 | BUILD SUCCESSFUL in 4m 24s |
| 166 | 56 actionable tasks: 56 executed |
| 167 | ==> Build completed |
| 168 |
| Passed |
| Passed |
| Passed |