From 3fae977ea65ebc04f5987e08930896a4540e3bd3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kriszti=C3=A1n=20G=C3=B6drei?= Date: Fri, 14 Jul 2023 15:29:44 +0200 Subject: [PATCH] Update bitrise-init (#138) --- go.mod | 2 +- go.sum | 4 +- .../bitrise-init/models/configbuilder.go | 21 +- .../bitrise-init/models/workflowbuilder.go | 2 + .../bitrise-io/bitrise-init/scanner/errors.go | 16 +- .../bitrise-init/scanners/android/android.go | 220 ++++++++++-------- .../bitrise-init/scanners/android/const.go | 16 -- .../bitrise-init/scanners/android/utility.go | 204 ++++++++-------- .../bitrise-init/scanners/ios/ios.go | 10 +- .../bitrise-init/scanners/ios/utility.go | 2 +- .../bitrise-init/scanners/ios/workflow.go | 118 +++++++--- vendor/modules.txt | 2 +- 12 files changed, 333 insertions(+), 284 deletions(-) delete mode 100644 vendor/github.com/bitrise-io/bitrise-init/scanners/android/const.go diff --git a/go.mod b/go.mod index 78eedce1..a07458cf 100644 --- a/go.mod +++ b/go.mod @@ -3,7 +3,7 @@ module github.com/bitrise-steplib/steps-project-scanner go 1.17 require ( - github.com/bitrise-io/bitrise-init v0.0.0-20230712122159-92865fb4e347 + github.com/bitrise-io/bitrise-init v0.0.0-20230714112932-ade0cb89e971 github.com/bitrise-io/go-steputils v1.0.5 github.com/bitrise-io/go-utils v1.0.1 github.com/bitrise-io/go-utils/v2 v2.0.0-alpha.18 diff --git a/go.sum b/go.sum index 02b1e989..6ce3dee4 100644 --- a/go.sum +++ b/go.sum @@ -8,8 +8,8 @@ github.com/bitrise-io/bitrise v0.0.0-20210519130014-380842fb41c1/go.mod h1:Jqf2P github.com/bitrise-io/bitrise v0.0.0-20220217113333-f2def13a7946 h1:c+dLJvoW8eswyrV88mJunzc+dSidsV0S4CCfGe5QZyo= github.com/bitrise-io/bitrise v0.0.0-20220217113333-f2def13a7946/go.mod h1:wZJS5uJ+mLhTbV4manrofZgGninsaMjMJndWC5OvcCY= github.com/bitrise-io/bitrise-init v0.0.0-20210518121553-1e678625c45d/go.mod h1:2bxvLp7xgXC3HsacG2Z5nn6WOjk8kbNOmLWjinnhnKg= -github.com/bitrise-io/bitrise-init v0.0.0-20230712122159-92865fb4e347 h1:wX/MVHVk2PtEbpimF8Lt7P4uYxiZGspjGfFz11VBIWY= -github.com/bitrise-io/bitrise-init v0.0.0-20230712122159-92865fb4e347/go.mod h1:4Pr0r3aDmcxkJ9k2SzfG1VPJ0X7IKBJApvDuUvPnLk0= +github.com/bitrise-io/bitrise-init v0.0.0-20230714112932-ade0cb89e971 h1:e8nxhJHHRemC3ZvmOGHZ8gJMBc2UjJ6VV/KmNAFQJCM= +github.com/bitrise-io/bitrise-init v0.0.0-20230714112932-ade0cb89e971/go.mod h1:4Pr0r3aDmcxkJ9k2SzfG1VPJ0X7IKBJApvDuUvPnLk0= github.com/bitrise-io/colorstring v0.0.0-20180614154802-a8cd70115192/go.mod h1:CIHVcxZUvsG99XUJV6JlR7okNsMMGY81jMvPC20W+O0= github.com/bitrise-io/depman v0.0.0-20160708153333-4c59bc31f02a/go.mod h1:jeK3Koe+wXMSwfl8t6M7kovGgXsayUJ5ybqo3gDJgts= github.com/bitrise-io/envman v0.0.0-20200512105748-919e33f391ee/go.mod h1:m8pTp1o3Sw9uzDxb1WRm5IBRnMau2iOvPMSnRCAhQNI= diff --git a/vendor/github.com/bitrise-io/bitrise-init/models/configbuilder.go b/vendor/github.com/bitrise-io/bitrise-init/models/configbuilder.go index 675c96e9..7c59ba6b 100644 --- a/vendor/github.com/bitrise-io/bitrise-init/models/configbuilder.go +++ b/vendor/github.com/bitrise-io/bitrise-init/models/configbuilder.go @@ -1,8 +1,6 @@ package models import ( - "errors" - bitriseModels "github.com/bitrise-io/bitrise/models" envmanModels "github.com/bitrise-io/envman/models" ) @@ -30,9 +28,7 @@ type ConfigBuilderModel struct { // NewDefaultConfigBuilder ... func NewDefaultConfigBuilder() *ConfigBuilderModel { return &ConfigBuilderModel{ - workflowBuilderMap: map[WorkflowID]*workflowBuilderModel{ - PrimaryWorkflowID: newDefaultWorkflowBuilder(), - }, + workflowBuilderMap: map[WorkflowID]*workflowBuilderModel{}, } } @@ -56,13 +52,18 @@ func (builder *ConfigBuilderModel) SetWorkflowDescriptionTo(workflow WorkflowID, workflowBuilder.Description = description } -// Generate ... -func (builder *ConfigBuilderModel) Generate(projectType string, appEnvs ...envmanModels.EnvironmentItemModel) (bitriseModels.BitriseDataModel, error) { - primaryWorkflowBuilder, ok := builder.workflowBuilderMap[PrimaryWorkflowID] - if !ok || primaryWorkflowBuilder == nil || len(primaryWorkflowBuilder.Steps) == 0 { - return bitriseModels.BitriseDataModel{}, errors.New("primary workflow not defined") +// SetWorkflowSummaryTo ... +func (builder *ConfigBuilderModel) SetWorkflowSummaryTo(workflow WorkflowID, summary string) { + workflowBuilder := builder.workflowBuilderMap[workflow] + if workflowBuilder == nil { + workflowBuilder = newDefaultWorkflowBuilder() + builder.workflowBuilderMap[workflow] = workflowBuilder } + workflowBuilder.Summary = summary +} +// Generate ... +func (builder *ConfigBuilderModel) Generate(projectType string, appEnvs ...envmanModels.EnvironmentItemModel) (bitriseModels.BitriseDataModel, error) { workflows := map[string]bitriseModels.WorkflowModel{} for workflowID, workflowBuilder := range builder.workflowBuilderMap { workflows[string(workflowID)] = workflowBuilder.generate() diff --git a/vendor/github.com/bitrise-io/bitrise-init/models/workflowbuilder.go b/vendor/github.com/bitrise-io/bitrise-init/models/workflowbuilder.go index 7b5288fd..2a2470da 100644 --- a/vendor/github.com/bitrise-io/bitrise-init/models/workflowbuilder.go +++ b/vendor/github.com/bitrise-io/bitrise-init/models/workflowbuilder.go @@ -5,6 +5,7 @@ import bitriseModels "github.com/bitrise-io/bitrise/models" type workflowBuilderModel struct { Steps []bitriseModels.StepListItemModel Description string + Summary string } func newDefaultWorkflowBuilder() *workflowBuilderModel { @@ -21,5 +22,6 @@ func (builder *workflowBuilderModel) generate() bitriseModels.WorkflowModel { return bitriseModels.WorkflowModel{ Steps: builder.Steps, Description: builder.Description, + Summary: builder.Summary, } } diff --git a/vendor/github.com/bitrise-io/bitrise-init/scanner/errors.go b/vendor/github.com/bitrise-io/bitrise-init/scanner/errors.go index d47dd1fc..1e9a6b5a 100644 --- a/vendor/github.com/bitrise-io/bitrise-init/scanner/errors.go +++ b/vendor/github.com/bitrise-io/bitrise-init/scanner/errors.go @@ -50,8 +50,8 @@ func newGenericDetail(errorMsg string) errormapper.DetailedError { func newNoPlatformDetectedGenericDetail() errormapper.DetailedError { return errormapper.DetailedError{ - Title: "We couldn’t recognize your platform.", - Description: fmt.Sprintf("Our auto-configurator supports %s projects. If you’re adding something else, skip this step and configure your Workflow manually.", strings.Join(availableScanners(), ", ")), + Title: "We couldn't recognize your platform.", + Description: fmt.Sprintf("Our auto-configurator supports %s projects. If you're adding something else, skip this step and configure your Workflow manually.", strings.Join(availableScanners(), ", ")), } } @@ -77,7 +77,7 @@ func newDetectPlatformFailedMatcher() *errormapper.PatternErrorMatcher { func newDetectPlatformFailedGenericDetail(errorMsg string) errormapper.DetailedError { return errormapper.DetailedError{ - Title: "We couldn’t parse your project files.", + Title: "We couldn't parse your project files.", Description: fmt.Sprintf("You can fix the problem and try again, or skip auto-configuration and set up your project manually. Our auto-configurator returned the following error:\n%s", errorMsg), } } @@ -98,7 +98,7 @@ var newOptionsFailedGenericDetail = newDetectPlatformFailedGenericDetail func newGradlewNotFoundDetail(errorMsg string, params ...string) errormapper.DetailedError { return errormapper.DetailedError{ - Title: "We couldn’t find your Gradle Wrapper. Please make sure there is a gradlew file in your project’s root directory.", + Title: "We couldn't find your Gradle Wrapper. Please make sure there is a gradlew file in your project's root directory.", Description: `The Gradle Wrapper ensures that the right Gradle version is installed and used for the build. You can find out more about the Gradle Wrapper in the Gradle docs.`, } } @@ -107,7 +107,7 @@ func newAppJSONIssueDetail(errorMsg string, params ...string) errormapper.Detail appJSONPath := params[0] entryName := params[1] return errormapper.DetailedError{ - Title: fmt.Sprintf("Your app.json file (%s) doesn’t have a %s field.", appJSONPath, entryName), + Title: fmt.Sprintf("Your app.json file (%s) doesn't have a %s field.", appJSONPath, entryName), Description: `The app.json file needs to contain the following entries: - name - displayName`, @@ -118,7 +118,7 @@ func newExpoAppJSONIssueDetail(errorMsg string, params ...string) errormapper.De appJSONPath := params[0] entryName := params[1] return errormapper.DetailedError{ - Title: fmt.Sprintf("Your app.json file (%s) doesn’t have a %s field.", appJSONPath, entryName), + Title: fmt.Sprintf("Your app.json file (%s) doesn't have a %s field.", appJSONPath, entryName), Description: `If your project uses Expo Kit, the app.json file needs to contain the following entries: - expo/name - expo/ios/bundleIdentifier @@ -128,7 +128,7 @@ func newExpoAppJSONIssueDetail(errorMsg string, params ...string) errormapper.De func newIonicCapacitorNotSupportedIssueDetail(errorMsg string, params ...string) errormapper.DetailedError { return errormapper.DetailedError{ - Title: "We couldn’t find your cordova.xml file.", - Description: `Our auto-configurator only supports Ionic projects with Cordova at the moment. If you’re trying to add a project with Ionic Capacitor, or something else, some Steps in your automatically generated Workflow might fail. To fix this, replace the failing Steps with script Steps in the Workflow editor later.`, + Title: "We couldn't find your cordova.xml file.", + Description: `Our auto-configurator only supports Ionic projects with Cordova at the moment. If you're trying to add a project with Ionic Capacitor, or something else, some Steps in your automatically generated Workflow might fail. To fix this, replace the failing Steps with script Steps in the Workflow editor later.`, } } diff --git a/vendor/github.com/bitrise-io/bitrise-init/scanners/android/android.go b/vendor/github.com/bitrise-io/bitrise-init/scanners/android/android.go index 0de65300..43db8516 100644 --- a/vendor/github.com/bitrise-io/bitrise-init/scanners/android/android.go +++ b/vendor/github.com/bitrise-io/bitrise-init/scanners/android/android.go @@ -1,14 +1,49 @@ package android import ( - "fmt" "path/filepath" "gopkg.in/yaml.v2" - "github.com/bitrise-io/bitrise-init/analytics" "github.com/bitrise-io/bitrise-init/models" - "github.com/bitrise-io/go-utils/log" + "github.com/bitrise-io/bitrise-init/steps" + envmanModels "github.com/bitrise-io/envman/models" +) + +const ( + ScannerName = "android" + ConfigName = "android-config" + DefaultConfigName = "default-android-config" + + testsWorkflowID = "run_tests" + testsWorkflowSummary = "Run your Android unit tests and get the test report." + testWorkflowDescription = "The workflow will first clone your Git repository, cache your Gradle dependencies, install Android tools, run your Android unit tests and save the test report." + + buildWorkflowID = "build_apk" + buildWorkflowSummary = "Run your Android unit tests and create an APK file to install your app on a device or share it with your team." + buildWorkflowDescription = "The workflow will first clone your Git repository, install Android tools, set the project's version code based on the build number, run Android lint and unit tests, build the project's APK file and save it." + + ProjectLocationInputKey = "project_location" + ProjectLocationInputEnvKey = "PROJECT_LOCATION" + ProjectLocationInputTitle = "The root directory of an Android project" + ProjectLocationInputSummary = "The root directory of your Android project, stored as an Environment Variable. In your Workflows, you can specify paths relative to this path. You can change this at any time." + + ModuleBuildGradlePathInputKey = "build_gradle_path" + + VariantInputKey = "variant" + VariantInputEnvKey = "VARIANT" + VariantInputTitle = "Variant" + VariantInputSummary = "Your Android build variant. You can add variants at any time, as well as further configure your existing variants later." + + ModuleInputKey = "module" + ModuleInputEnvKey = "MODULE" + ModuleInputTitle = "Module" + ModuleInputSummary = "Modules provide a container for your Android project's source code, resource files, and app level settings, such as the module-level build file and Android manifest file. Each module can be independently built, tested, and debugged. You can add new modules to your Bitrise builds at any time." + + GradlewPathInputKey = "gradlew_path" + + CacheLevelInputKey = "cache_level" + CacheLevelNone = "none" ) // Scanner ... @@ -22,12 +57,12 @@ func NewScanner() *Scanner { } // Name ... -func (Scanner) Name() string { +func (scanner *Scanner) Name() string { return ScannerName } // ExcludedScannerNames ... -func (*Scanner) ExcludedScannerNames() []string { +func (scanner *Scanner) ExcludedScannerNames() []string { return nil } @@ -40,95 +75,6 @@ func (scanner *Scanner) DetectPlatform(searchDir string) (_ bool, err error) { return detected, err } -func detect(searchDir string) ([]Project, error) { - projectFiles := fileGroups{ - {"build.gradle", "build.gradle.kts"}, - {"settings.gradle", "settings.gradle.kts"}, - } - skipDirs := []string{".git", "CordovaLib", "node_modules"} - - log.TInfof("Searching for android files") - - projectRoots, err := walkMultipleFileGroups(searchDir, projectFiles, skipDirs) - if err != nil { - return nil, fmt.Errorf("failed to search for build.gradle files, error: %s", err) - } - - log.TPrintf("%d android files detected", len(projectRoots)) - for _, file := range projectRoots { - log.TPrintf("- %s", file) - } - - if len(projectRoots) == 0 { - return nil, nil - } - log.TSuccessf("Platform detected") - - projects, err := parseProjects(searchDir, projectRoots) - if err != nil { - return nil, err - } - - return projects, nil -} - -func parseProjects(searchDir string, projectRoots []string) ([]Project, error) { - var ( - lastErr error - projects []Project - ) - - for _, projectRoot := range projectRoots { - var warnings models.Warnings - - log.TInfof("Investigating Android project: %s", projectRoot) - - exists, err := containsLocalProperties(projectRoot) - if err != nil { - lastErr = err - log.TWarnf("%s", err) - - continue - } - if exists { - containsLocalPropertiesWarning := fmt.Sprintf("the local.properties file should NOT be checked into Version Control Systems, as it contains information specific to your local configuration, the location of the file is: %s", filepath.Join(projectRoot, "local.properties")) - warnings = []string{containsLocalPropertiesWarning} - } - - if err := checkGradlew(projectRoot); err != nil { - lastErr = err - log.TWarnf("%s", err) - - continue - } - - relProjectRoot, err := filepath.Rel(searchDir, projectRoot) - if err != nil { - lastErr = err - log.TWarnf("%s", err) - - continue - } - - icons, err := LookupIcons(projectRoot, searchDir) - if err != nil { - analytics.LogInfo("android-icon-lookup", analytics.DetectorErrorData("android", err), "Failed to lookup android icon") - } - - projects = append(projects, Project{ - RelPath: relProjectRoot, - Icons: icons, - Warnings: warnings, - }) - } - - if len(projects) == 0 { - return []Project{}, lastErr - } - - return projects, nil -} - // Options ... func (scanner *Scanner) Options() (models.OptionNode, models.Warnings, models.Icons, error) { projectLocationOption := models.NewOption(ProjectLocationInputTitle, ProjectLocationInputSummary, ProjectLocationInputEnvKey, models.TypeSelector) @@ -207,3 +153,89 @@ func (scanner *Scanner) DefaultConfigs() (models.BitriseConfigMap, error) { DefaultConfigName: string(data), }, nil } + +func (scanner *Scanner) generateConfigBuilder(repoAccess models.RepoAccess) models.ConfigBuilderModel { + configBuilder := models.NewDefaultConfigBuilder() + + projectLocationEnv, gradlewPath, moduleEnv, variantEnv := "$"+ProjectLocationInputEnvKey, "$"+ProjectLocationInputEnvKey+"/gradlew", "$"+ModuleInputEnvKey, "$"+VariantInputEnvKey + + //-- test + configBuilder.AppendStepListItemsTo(testsWorkflowID, steps.DefaultPrepareStepList(steps.PrepareListParams{ + RepoAccess: repoAccess})...) + configBuilder.AppendStepListItemsTo(testsWorkflowID, steps.RestoreGradleCache()) + configBuilder.AppendStepListItemsTo(testsWorkflowID, steps.InstallMissingAndroidToolsStepListItem( + envmanModels.EnvironmentItemModel{GradlewPathInputKey: gradlewPath}, + )) + configBuilder.AppendStepListItemsTo(testsWorkflowID, steps.AndroidUnitTestStepListItem( + envmanModels.EnvironmentItemModel{ + ProjectLocationInputKey: projectLocationEnv, + }, + envmanModels.EnvironmentItemModel{ + VariantInputKey: variantEnv, + }, + envmanModels.EnvironmentItemModel{ + CacheLevelInputKey: CacheLevelNone, + }, + )) + configBuilder.AppendStepListItemsTo(testsWorkflowID, steps.SaveGradleCache()) + configBuilder.AppendStepListItemsTo(testsWorkflowID, steps.DefaultDeployStepList()...) + configBuilder.SetWorkflowSummaryTo(testsWorkflowID, testsWorkflowSummary) + configBuilder.SetWorkflowDescriptionTo(testsWorkflowID, testWorkflowDescription) + + //-- build + configBuilder.AppendStepListItemsTo(buildWorkflowID, steps.DefaultPrepareStepList(steps.PrepareListParams{ + RepoAccess: repoAccess, + })...) + configBuilder.AppendStepListItemsTo(buildWorkflowID, steps.InstallMissingAndroidToolsStepListItem( + envmanModels.EnvironmentItemModel{GradlewPathInputKey: gradlewPath}, + )) + + configBuilder.AppendStepListItemsTo(buildWorkflowID, steps.ChangeAndroidVersionCodeAndVersionNameStepListItem( + envmanModels.EnvironmentItemModel{ModuleBuildGradlePathInputKey: filepath.Join(projectLocationEnv, moduleEnv, "build.gradle")}, + )) + + configBuilder.AppendStepListItemsTo(buildWorkflowID, steps.AndroidLintStepListItem( + envmanModels.EnvironmentItemModel{ + ProjectLocationInputKey: projectLocationEnv, + }, + envmanModels.EnvironmentItemModel{ + VariantInputKey: variantEnv, + }, + envmanModels.EnvironmentItemModel{ + CacheLevelInputKey: CacheLevelNone, + }, + )) + configBuilder.AppendStepListItemsTo(buildWorkflowID, steps.AndroidUnitTestStepListItem( + envmanModels.EnvironmentItemModel{ + ProjectLocationInputKey: projectLocationEnv, + }, + envmanModels.EnvironmentItemModel{ + VariantInputKey: variantEnv, + }, + envmanModels.EnvironmentItemModel{ + CacheLevelInputKey: CacheLevelNone, + }, + )) + + configBuilder.AppendStepListItemsTo(buildWorkflowID, steps.AndroidBuildStepListItem( + envmanModels.EnvironmentItemModel{ + ProjectLocationInputKey: projectLocationEnv, + }, + envmanModels.EnvironmentItemModel{ + ModuleInputKey: moduleEnv, + }, + envmanModels.EnvironmentItemModel{ + VariantInputKey: variantEnv, + }, + envmanModels.EnvironmentItemModel{ + CacheLevelInputKey: CacheLevelNone, + }, + )) + configBuilder.AppendStepListItemsTo(buildWorkflowID, steps.SignAPKStepListItem()) + configBuilder.AppendStepListItemsTo(buildWorkflowID, steps.DefaultDeployStepList()...) + + configBuilder.SetWorkflowDescriptionTo(buildWorkflowID, buildWorkflowDescription) + configBuilder.SetWorkflowSummaryTo(buildWorkflowID, buildWorkflowSummary) + + return *configBuilder +} diff --git a/vendor/github.com/bitrise-io/bitrise-init/scanners/android/const.go b/vendor/github.com/bitrise-io/bitrise-init/scanners/android/const.go deleted file mode 100644 index 0cc8df5e..00000000 --- a/vendor/github.com/bitrise-io/bitrise-init/scanners/android/const.go +++ /dev/null @@ -1,16 +0,0 @@ -package android - -const ( - primaryWorkflowDescription = `Runs tests. - -Next steps: -- Check out [Getting started with Android apps](https://devcenter.bitrise.io/en/getting-started/getting-started-with-android-apps.html). -` - - deployWorkflowDescription = `Deploys app using [Deploy to bitrise.io Step](https://devcenter.bitrise.io/en/getting-started/getting-started-with-android-apps.html#deploying-an-android-app-to-bitrise-io-53056). - -Next steps: -- Check out [Getting started with Android apps](https://devcenter.bitrise.io/en/getting-started/getting-started-with-android-apps.html) for signing and deployment options. -- [Set up code signing with *Android Sign* Step](https://devcenter.bitrise.io/en/code-signing/android-code-signing/android-code-signing-using-the-android-sign-step.html). -` -) diff --git a/vendor/github.com/bitrise-io/bitrise-init/scanners/android/utility.go b/vendor/github.com/bitrise-io/bitrise-init/scanners/android/utility.go index c74d949d..af88cea7 100644 --- a/vendor/github.com/bitrise-io/bitrise-init/scanners/android/utility.go +++ b/vendor/github.com/bitrise-io/bitrise-init/scanners/android/utility.go @@ -2,12 +2,14 @@ package android import ( "errors" + "fmt" "os" "path/filepath" + "github.com/bitrise-io/bitrise-init/analytics" + "github.com/bitrise-io/bitrise-init/models" - "github.com/bitrise-io/bitrise-init/steps" - envmanModels "github.com/bitrise-io/envman/models" + "github.com/bitrise-io/go-utils/log" "github.com/bitrise-io/go-utils/pathutil" ) @@ -16,40 +18,100 @@ type fileGroups [][]string var pathUtilIsPathExists = pathutil.IsPathExists var filePathWalk = filepath.Walk -// Constants ... -const ( - ScannerName = "android" - ConfigName = "android-config" - DefaultConfigName = "default-android-config" +// Project is an Android project on the filesystem +type Project struct { + RelPath string + Icons models.Icons + Warnings models.Warnings +} - ProjectLocationInputKey = "project_location" - ProjectLocationInputEnvKey = "PROJECT_LOCATION" - ProjectLocationInputTitle = "The root directory of an Android project" - ProjectLocationInputSummary = "The root directory of your Android project, stored as an Environment Variable. In your Workflows, you can specify paths relative to this path. You can change this at any time." +func detect(searchDir string) ([]Project, error) { + projectFiles := fileGroups{ + {"build.gradle", "build.gradle.kts"}, + {"settings.gradle", "settings.gradle.kts"}, + } + skipDirs := []string{".git", "CordovaLib", "node_modules"} - ModuleBuildGradlePathInputKey = "build_gradle_path" + log.TInfof("Searching for android files") - VariantInputKey = "variant" - VariantInputEnvKey = "VARIANT" - VariantInputTitle = "Variant" - VariantInputSummary = "Your Android build variant. You can add variants at any time, as well as further configure your existing variants later." + projectRoots, err := walkMultipleFileGroups(searchDir, projectFiles, skipDirs) + if err != nil { + return nil, fmt.Errorf("failed to search for build.gradle files, error: %s", err) + } - ModuleInputKey = "module" - ModuleInputEnvKey = "MODULE" - ModuleInputTitle = "Module" - ModuleInputSummary = "Modules provide a container for your Android project's source code, resource files, and app level settings, such as the module-level build file and Android manifest file. Each module can be independently built, tested, and debugged. You can add new modules to your Bitrise builds at any time." + log.TPrintf("%d android files detected", len(projectRoots)) + for _, file := range projectRoots { + log.TPrintf("- %s", file) + } - GradlewPathInputKey = "gradlew_path" + if len(projectRoots) == 0 { + return nil, nil + } + log.TSuccessf("Platform detected") - CacheLevelInputKey = "cache_level" - CacheLevelNone = "none" -) + projects, err := parseProjects(searchDir, projectRoots) + if err != nil { + return nil, err + } -// Project is an Android project on the filesystem -type Project struct { - RelPath string - Icons models.Icons - Warnings models.Warnings + return projects, nil +} + +func parseProjects(searchDir string, projectRoots []string) ([]Project, error) { + var ( + lastErr error + projects []Project + ) + + for _, projectRoot := range projectRoots { + var warnings models.Warnings + + log.TInfof("Investigating Android project: %s", projectRoot) + + exists, err := containsLocalProperties(projectRoot) + if err != nil { + lastErr = err + log.TWarnf("%s", err) + + continue + } + if exists { + containsLocalPropertiesWarning := fmt.Sprintf("the local.properties file should NOT be checked into Version Control Systems, as it contains information specific to your local configuration, the location of the file is: %s", filepath.Join(projectRoot, "local.properties")) + warnings = []string{containsLocalPropertiesWarning} + } + + if err := checkGradlew(projectRoot); err != nil { + lastErr = err + log.TWarnf("%s", err) + + continue + } + + relProjectRoot, err := filepath.Rel(searchDir, projectRoot) + if err != nil { + lastErr = err + log.TWarnf("%s", err) + + continue + } + + icons, err := LookupIcons(projectRoot, searchDir) + if err != nil { + analytics.LogInfo("android-icon-lookup", analytics.DetectorErrorData("android", err), "Failed to lookup android icon") + } + + projects = append(projects, Project{ + RelPath: relProjectRoot, + Icons: icons, + Warnings: warnings, + }) + } + + if len(projects) == 0 { + return []Project{}, lastErr + } + + return projects, nil } func walk(src string, fn func(path string, info os.FileInfo) error) error { @@ -140,87 +202,3 @@ that the right Gradle version is installed and used for the build. More info/gui } return nil } - -func (scanner *Scanner) generateConfigBuilder(repoAccess models.RepoAccess) models.ConfigBuilderModel { - configBuilder := models.NewDefaultConfigBuilder() - - projectLocationEnv, gradlewPath, moduleEnv, variantEnv := "$"+ProjectLocationInputEnvKey, "$"+ProjectLocationInputEnvKey+"/gradlew", "$"+ModuleInputEnvKey, "$"+VariantInputEnvKey - - //-- primary - configBuilder.AppendStepListItemsTo(models.PrimaryWorkflowID, steps.DefaultPrepareStepList(steps.PrepareListParams{ - RepoAccess: repoAccess})...) - configBuilder.AppendStepListItemsTo(models.PrimaryWorkflowID, steps.RestoreGradleCache()) - configBuilder.AppendStepListItemsTo(models.PrimaryWorkflowID, steps.InstallMissingAndroidToolsStepListItem( - envmanModels.EnvironmentItemModel{GradlewPathInputKey: gradlewPath}, - )) - configBuilder.AppendStepListItemsTo(models.PrimaryWorkflowID, steps.AndroidUnitTestStepListItem( - envmanModels.EnvironmentItemModel{ - ProjectLocationInputKey: projectLocationEnv, - }, - envmanModels.EnvironmentItemModel{ - VariantInputKey: variantEnv, - }, - envmanModels.EnvironmentItemModel{ - CacheLevelInputKey: CacheLevelNone, - }, - )) - configBuilder.AppendStepListItemsTo(models.PrimaryWorkflowID, steps.SaveGradleCache()) - configBuilder.AppendStepListItemsTo(models.PrimaryWorkflowID, steps.DefaultDeployStepList()...) - configBuilder.SetWorkflowDescriptionTo(models.PrimaryWorkflowID, primaryWorkflowDescription) - - //-- deploy - configBuilder.AppendStepListItemsTo(models.DeployWorkflowID, steps.DefaultPrepareStepList(steps.PrepareListParams{ - RepoAccess: repoAccess, - })...) - configBuilder.AppendStepListItemsTo(models.DeployWorkflowID, steps.InstallMissingAndroidToolsStepListItem( - envmanModels.EnvironmentItemModel{GradlewPathInputKey: gradlewPath}, - )) - - configBuilder.AppendStepListItemsTo(models.DeployWorkflowID, steps.ChangeAndroidVersionCodeAndVersionNameStepListItem( - envmanModels.EnvironmentItemModel{ModuleBuildGradlePathInputKey: filepath.Join(projectLocationEnv, moduleEnv, "build.gradle")}, - )) - - configBuilder.AppendStepListItemsTo(models.DeployWorkflowID, steps.AndroidLintStepListItem( - envmanModels.EnvironmentItemModel{ - ProjectLocationInputKey: projectLocationEnv, - }, - envmanModels.EnvironmentItemModel{ - VariantInputKey: variantEnv, - }, - envmanModels.EnvironmentItemModel{ - CacheLevelInputKey: CacheLevelNone, - }, - )) - configBuilder.AppendStepListItemsTo(models.DeployWorkflowID, steps.AndroidUnitTestStepListItem( - envmanModels.EnvironmentItemModel{ - ProjectLocationInputKey: projectLocationEnv, - }, - envmanModels.EnvironmentItemModel{ - VariantInputKey: variantEnv, - }, - envmanModels.EnvironmentItemModel{ - CacheLevelInputKey: CacheLevelNone, - }, - )) - - configBuilder.AppendStepListItemsTo(models.DeployWorkflowID, steps.AndroidBuildStepListItem( - envmanModels.EnvironmentItemModel{ - ProjectLocationInputKey: projectLocationEnv, - }, - envmanModels.EnvironmentItemModel{ - ModuleInputKey: moduleEnv, - }, - envmanModels.EnvironmentItemModel{ - VariantInputKey: variantEnv, - }, - envmanModels.EnvironmentItemModel{ - CacheLevelInputKey: CacheLevelNone, - }, - )) - configBuilder.AppendStepListItemsTo(models.DeployWorkflowID, steps.SignAPKStepListItem()) - configBuilder.AppendStepListItemsTo(models.DeployWorkflowID, steps.DefaultDeployStepList()...) - - configBuilder.SetWorkflowDescriptionTo(models.DeployWorkflowID, deployWorkflowDescription) - - return *configBuilder -} diff --git a/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/ios.go b/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/ios.go index f64b8423..e8ac5fc7 100644 --- a/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/ios.go +++ b/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/ios.go @@ -24,7 +24,7 @@ func NewScanner() *Scanner { } // Name ... -func (Scanner) Name() string { +func (scanner *Scanner) Name() string { return string(XcodeProjectTypeIOS) } @@ -48,7 +48,7 @@ func (scanner *Scanner) DetectPlatform(searchDir string) (bool, error) { } // ExcludedScannerNames ... -func (Scanner) ExcludedScannerNames() []string { +func (scanner *Scanner) ExcludedScannerNames() []string { return []string{} } @@ -65,7 +65,7 @@ func (scanner *Scanner) Options() (models.OptionNode, models.Warnings, models.Ic } // DefaultOptions ... -func (Scanner) DefaultOptions() models.OptionNode { +func (scanner *Scanner) DefaultOptions() models.OptionNode { return GenerateDefaultOptions(XcodeProjectTypeIOS) } @@ -74,11 +74,11 @@ func (scanner *Scanner) Configs(repoAccess models.RepoAccess) (models.BitriseCon } // DefaultConfigs ... -func (Scanner) DefaultConfigs() (models.BitriseConfigMap, error) { +func (scanner *Scanner) DefaultConfigs() (models.BitriseConfigMap, error) { return GenerateDefaultConfig(XcodeProjectTypeIOS) } // GetProjectType returns the project_type property used in a bitrise config -func (Scanner) GetProjectType() string { +func (scanner *Scanner) GetProjectType() string { return string(XcodeProjectTypeIOS) } diff --git a/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/utility.go b/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/utility.go index eca6a068..70c293c2 100644 --- a/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/utility.go +++ b/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/utility.go @@ -614,7 +614,7 @@ func GenerateConfigBuilder( exportMethod: exportMethod, } - createPrimaryWorkflow(params) + createVerificationWorkflow(params) if !isSPMProject { createDeployWorkflow(params) diff --git a/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/workflow.go b/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/workflow.go index ab1e6489..0b0e69be 100644 --- a/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/workflow.go +++ b/vendor/github.com/bitrise-io/bitrise-init/scanners/ios/workflow.go @@ -15,24 +15,29 @@ const ( AutomaticCodeSigningValue = "api-key" CacheLevelKey = "cache_level" CacheLevelNone = "none" -) -const primaryTestDescription = `The workflow executes the tests. The *retry_on_failure* test repetition mode is enabled.` + // test workflow + primaryWorkflowID = "primary" + + testWorkflowID = "run_tests" + testWorkflowSummary = "Run your Xcode tests and get the test report." + testWorkflowDescription = "The workflow will first clone your Git repository, cache and install your project's dependencies if any, run your Xcode tests and save the test results." -const primaryBuildOnlyDescription = `The workflow only builds the project because the project scanner could not find any tests.` + buildWorkflowID = "build" + buildWorkflowSummary = "Build your Xcode project." + buildWorkflowDescription = "The workflow will first clone your Git repository, cache and install your project's dependencies if any and build your project." -const primaryCommonDescription = `Next steps: -- Check out [Getting started with iOS apps](https://devcenter.bitrise.io/en/getting-started/getting-started-with-ios-apps.html). -` + // deploy workflow + deployWorkflowID = "deploy" -const deployDescription = `The workflow tests, builds and deploys the app using *Deploy to bitrise.io* step. + archiveAndExportWorkflowID = "archive_and_export_app" -For testing the *retry_on_failure* test repetition mode is enabled. + archiveAndExportWorkflowWithTestsSummary = "Run your Xcode tests and create an IPA file to install your app on a device or share it with your team." + archiveAndExportWorkflowWithTestsDescription = "The workflow will first clone your Git repository, cache and install your project's dependencies if any, run your Xcode tests, export an IPA file from the project and save it." -Next steps: -- Set up [Connecting to an Apple service with API key](https://devcenter.bitrise.io/en/accounts/connecting-to-services/connecting-to-an-apple-service-with-api-key.html##). -- Or further customise code signing following our [iOS code signing](https://devcenter.bitrise.io/en/code-signing/ios-code-signing.html) guide. -` + archiveAndExportWorkflowWithoutTestsSummary = "Create an IPA file to install your app on a device or share it with your team." + archiveAndExportWorkflowWithoutTestsDescription = "The workflow will first clone your Git repository, cache and install your project's dependencies if any, export an IPA file from the project and save it." +) type workflowSetupParams struct { projectType XcodeProjectType @@ -47,36 +52,83 @@ type workflowSetupParams struct { exportMethod string } -func createPrimaryWorkflow(params workflowSetupParams) { - identifier := models.PrimaryWorkflowID - addSharedSetupSteps(identifier, params, false, true) +func createVerificationWorkflow(params workflowSetupParams) { + id, summary, description := verificationWorkflowIDSummaryAndDescription(params.projectType, params.hasTests) - var description string + addSharedSetupSteps(models.WorkflowID(id), params, false, true) if params.hasTests { - description = primaryTestDescription - addTestStep(identifier, params.configBuilder, params.projectType) + addTestStep(models.WorkflowID(id), params.configBuilder, params.projectType) } else { - description = primaryBuildOnlyDescription - addBuildStep(identifier, params.configBuilder, params.projectType) + addBuildStep(models.WorkflowID(id), params.configBuilder, params.projectType) } - addSharedTeardownSteps(identifier, params, true) - addDescription(params.projectType, identifier, params.configBuilder, description+"\n\n"+primaryCommonDescription) + addSharedTeardownSteps(models.WorkflowID(id), params, true) + addSummary(models.WorkflowID(id), params.configBuilder, summary) + addDescription(models.WorkflowID(id), params.configBuilder, description) } func createDeployWorkflow(params workflowSetupParams) { - identifier := models.DeployWorkflowID + id, summary, description := deployWorkflowIDSummaryAndDescription(params.projectType, params.hasTests) + includeCertificateAndProfileInstallStep := params.projectType == XcodeProjectTypeMacOS - addSharedSetupSteps(identifier, params, includeCertificateAndProfileInstallStep, false) + addSharedSetupSteps(models.WorkflowID(id), params, includeCertificateAndProfileInstallStep, false) if params.hasTests { - addTestStep(identifier, params.configBuilder, params.projectType) + addTestStep(models.WorkflowID(id), params.configBuilder, params.projectType) + } + + addArchiveStep(models.WorkflowID(id), params.configBuilder, params.projectType, params.hasAppClip, params.exportMethod) + addSharedTeardownSteps(models.WorkflowID(id), params, false) // No cache in deploy workflows + addSummary(models.WorkflowID(id), params.configBuilder, summary) + addDescription(models.WorkflowID(id), params.configBuilder, description) +} + +func verificationWorkflowIDSummaryAndDescription(projectType XcodeProjectType, hasTests bool) (string, string, string) { + var id string + var summary string + var description string + + if projectType == XcodeProjectTypeMacOS { + id = primaryWorkflowID + summary = "" + description = "" + } else { + if hasTests { + id = testWorkflowID + summary = testWorkflowSummary + description = testWorkflowDescription + } else { + id = buildWorkflowID + summary = buildWorkflowSummary + description = buildWorkflowDescription + } } - addArchiveStep(identifier, params.configBuilder, params.projectType, params.hasAppClip, params.exportMethod) - addSharedTeardownSteps(identifier, params, false) // No cache in deploy workflows - addDescription(params.projectType, identifier, params.configBuilder, deployDescription) + return id, summary, description +} + +func deployWorkflowIDSummaryAndDescription(projectType XcodeProjectType, hasTests bool) (string, string, string) { + var id string + var summary string + var description string + + if projectType == XcodeProjectTypeMacOS { + id = deployWorkflowID + summary = "" + description = "" + } else { + id = archiveAndExportWorkflowID + if hasTests { + summary = archiveAndExportWorkflowWithTestsSummary + description = archiveAndExportWorkflowWithTestsDescription + } else { + summary = archiveAndExportWorkflowWithoutTestsSummary + description = archiveAndExportWorkflowWithoutTestsDescription + } + } + + return id, summary, description } // Add steps @@ -167,14 +219,14 @@ func addSharedTeardownSteps(workflow models.WorkflowID, params workflowSetupPara params.configBuilder.AppendStepListItemsTo(workflow, steps.DefaultDeployStepList()...) } -func addDescription(projectType XcodeProjectType, workflow models.WorkflowID, configBuilder *models.ConfigBuilderModel, description string) { - if projectType != XcodeProjectTypeIOS { - return - } - +func addDescription(workflow models.WorkflowID, configBuilder *models.ConfigBuilderModel, description string) { configBuilder.SetWorkflowDescriptionTo(workflow, description) } +func addSummary(workflow models.WorkflowID, configBuilder *models.ConfigBuilderModel, summary string) { + configBuilder.SetWorkflowSummaryTo(workflow, summary) +} + // Helpers func baseXcodeStepInputModels() []envmanModels.EnvironmentItemModel { diff --git a/vendor/modules.txt b/vendor/modules.txt index 536c3078..16f322bf 100644 --- a/vendor/modules.txt +++ b/vendor/modules.txt @@ -7,7 +7,7 @@ github.com/beevik/etree # github.com/bitrise-io/bitrise v0.0.0-20220217113333-f2def13a7946 ## explicit; go 1.16 github.com/bitrise-io/bitrise/models -# github.com/bitrise-io/bitrise-init v0.0.0-20230712122159-92865fb4e347 +# github.com/bitrise-io/bitrise-init v0.0.0-20230714112932-ade0cb89e971 ## explicit; go 1.17 github.com/bitrise-io/bitrise-init/analytics github.com/bitrise-io/bitrise-init/errormapper