Расположение пакета sdk для настройки сборки Android в конвейере Azure DevOps

#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