#android #gradle #azure-devops
#Android #gradle #azure-devops
Вопрос:
Я пытаюсь создать приложение для Android с использованием конвейера yaml. Задача сборки gradle жалуется, что не может найти корень Android sdk. Я пробовал как локальный файл.properties, так и переменную среды ANDROID_SDK_ROOT, и ни один из них не работает. Это мой конвейер сборки:
# Android
# Build your Android project with Gradle.
# Add steps that test, sign, and distribute the APK, save build artifacts, and more:
# https://learn.microsoft.com/azure/devops/pipelines/languages/android
trigger:
- master
- dev
pool:
name: 'Default'
steps:
- task: UseDotNet@2
inputs:
version: '2.2.x'
packageType: runtime
- task: GitVersion@5
displayName: GitVersion
inputs:
useConfigFile: true
configFilePath: GitVersion.yml
# trying to set the env variable doesn't work.
# - task: PowerShell@2
# inputs:
# targetType: 'inline'
# script: |
# # Write your PowerShell commands here.
# [Environment]::SetEnvironmentVariable("ANDROID_SDK_ROOT", "C:UsersAdministratorAppDataLocalAndroidSdk", "User")
- task: file-creator@6
inputs:
filepath: '$(System.DefaultWorkingDirectory)/local.properties'
filecontent: 'sdk.dir=C:/Users/Administrator/AppData/Local/Android/Sdk'
fileoverwrite: true
# trying to execute gradlew manually does not work
# - task: CmdLine@2
# inputs:
# script: |
# gradlew.bat assembleDebug
# workingDirectory: '$(System.DefaultWorkingDirectory)'
- task: Gradle@2
inputs:
workingDirectory: '$(System.DefaultWorkingDirectory)'
gradleWrapperFile: 'gradlew'
gradleOptions: '-Xmx3072m'
publishJUnitResults: false
testResultsFiles: '**/TEST-*.xml'
tasks: 'assembleDebug'
Это вывод:
Help : https://learn.microsoft.com/azure/devops/pipelines/tasks/build/gradle
==============================================================================
SYSTEMVSSCONNECTION exists true
C:Windowssystem32cmd.exe /D /S /C "C:VSTS_work8sgradlew.bat -p C:VSTS_work8s assembleDebug"
Starting a Gradle Daemon, 1 incompatible and 4 stopped Daemons could not be reused, use --status for details
> Configure project :app
registerResGeneratingTask is deprecated, use registerGeneratedResFolders(FileCollection)
registerResGeneratingTask is deprecated, use registerGeneratedResFolders(FileCollection)
registerResGeneratingTask is deprecated, use registerGeneratedResFolders(FileCollection)
FAILURE: Build failed with an exception.
* What went wrong:
Could not determine the dependencies of task ':app:compileDebugJavaWithJavac'.
> SDK location not found. Define location with an ANDROID_SDK_ROOT environment variable or by setting the sdk.dir path in your project's local properties file at 'C:VSTS_work8slocal.properties'.
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. Run with --scan to get full insights.
* Get more help at https://help.gradle.org
BUILD FAILED in 16s
Error: The process 'C:VSTS_work8sgradlew.bat' failed with exit code 1
at ExecState._setResult (C:VSTS_work_tasksGradle_8d8eebd8-2b94-4c97-85af-839254cc6da42.176.0node_modulesazure-pipelines-task-libtoolrunner.js:816:25)
at ExecState.CheckComplete (C:VSTS_work_tasksGradle_8d8eebd8-2b94-4c97-85af-839254cc6da42.176.0node_modulesazure-pipelines-task-libtoolrunner.js:799:18)
at ChildProcess.<anonymous> (C:VSTS_work_tasksGradle_8d8eebd8-2b94-4c97-85af-839254cc6da42.176.0node_modulesazure-pipelines-task-libtoolrunner.js:721:19)
at emitTwo (events.js:106:13)
at ChildProcess.emit (events.js:191:7)
at maybeClose (internal/child_process.js:920:16)
at Process.ChildProcess._handle.onexit (internal/child_process.js:230:5)
##[error]Error: The process 'C:VSTS_work8sgradlew.bat' failed with exit code 1
Finishing: Gradle
Если я подключусь к агенту сборки и запущу gradlew вручную с сгенерированным файлом local.properties, присутствующим в командной строке, сборка завершится успешно, поэтому я не уверен, в чем проблема с ее запуском в конвейере.
Ответ №1:
Вы можете установить переменные среды в azure pipeline, определив их в разделе Переменные. Вы можете добавить ниже в свой конвейер yaml.
variables:
ANDROID_SDK_ROOT: 'C:UsersAdministratorAppDataLocalAndroidSdk'
Вы также можете установить переменную среды ANDROID_SDK_ROOT с помощью команды task.setvariable
ведения журнала в сценариях. Для примера ниже.
steps:
- powershell: echo "##vso[task.setvariable variable=ANDROID_SDK_ROOT]C:UsersAdministratorAppDataLocalAndroidSdk"
Комментарии:
1. Не повезло. Есть ли что-нибудь, что я могу включить, чтобы включить какое-либо подробное ведение журнала?
Ответ №2:
Я разобрался с проблемой. Я установил Android sdk в учетной записи администратора, но devops создал отдельного пользователя Windows для сборки. Установка Android sdk для этого пользователя исправила мою сборку.
Комментарии:
1. У меня такая же проблема. Я использую только одну локальную учетную запись администратора. тем не менее, у меня ошибка. Могу ли я узнать какие-либо варианты? @Steveadoo