diff --git a/.teamcity/configurations/bazelBsp/bazelE2eTests.kts b/.teamcity/configurations/bazelBsp/bazelE2eTests.kts index c4df94e64..fb8237113 100644 --- a/.teamcity/configurations/bazelBsp/bazelE2eTests.kts +++ b/.teamcity/configurations/bazelBsp/bazelE2eTests.kts @@ -9,35 +9,46 @@ import jetbrains.buildServer.configs.kotlin.v2019_2.buildSteps.script open class BazelBspE2ETestsBuildType( targets: String, - steps: (BuildSteps.() -> Unit)? = null + steps: (BuildSteps.() -> Unit)? = null, + bazelVersion: String, ) : BaseConfiguration.BaseBuildType( - - name = "[e2e tests] $targets test", + name = "[e2e tests] $targets test with bazel $bazelVersion", vcsRoot = BaseConfiguration.BazelBspVcs, setupSteps = true, steps = { - if (steps != null) { - steps.invoke(this) + steps?.invoke(this) + + script { + this.name = "set bazel version" + scriptContent = """ + |#!/bin/bash + |set -euxo pipefail + | + |export USE_BAZEL_VERSION=$bazelVersion + |echo "##teamcity[setParameter name='env.USE_BAZEL_VERSION' value='${'$'}USE_BAZEL_VERSION']" + """.trimMargin() } bazel { this.name = "test $targets" this.command = "run" this.targets = targets logging = BazelStep.Verbosity.Diagnostic - arguments = "--test_output=errors" param("toolPath", "/usr/local/bin") } - }, - requirements = { - contains("cloud.amazon.agent-name-prefix", "Linux-Large") } ) -object SampleRepoE2ETest : BazelBspE2ETestsBuildType( +object SampleRepoBazel6E2ETest : BazelBspE2ETestsBuildType( targets = "//e2e:BazelBspSampleRepoTest", + bazelVersion = "6.2.1" ) -object BazelBspLocalJdkTest : BazelBspE2ETestsBuildType( +object SampleRepoBazel5E2ETest : BazelBspE2ETestsBuildType( + targets = "//e2e:BazelBspSampleRepoTest", + bazelVersion = "5.4.1" +) + +object BazelBspLocalBazel6JdkTest : BazelBspE2ETestsBuildType( targets = "//e2e:BazelBspLocalJdkTest", steps = { script { @@ -49,13 +60,32 @@ object BazelBspLocalJdkTest : BazelBspE2ETestsBuildType( echo "##teamcity[setParameter name='env.JAVA_HOME' value='%env.JDK_17_0%']" """.trimIndent() } - } + }, + bazelVersion = "6.2.1" ) -object BazelBspRemoteJdkTest : BazelBspE2ETestsBuildType( +object BazelBspLocalBazel5JdkTest : BazelBspE2ETestsBuildType( + targets = "//e2e:BazelBspLocalJdkTest", + steps = { + script { + this.name = "set JDK to 17" + scriptContent = """ + #!/bin/bash + set -euxo pipefail + + echo "##teamcity[setParameter name='env.JAVA_HOME' value='%env.JDK_17_0%']" + """.trimIndent() + } + }, + bazelVersion = "5.4.1" +) + +object BazelBspRemoteBazel6JdkTest : BazelBspE2ETestsBuildType( targets = "//e2e:BazelBspRemoteJdkTest", + bazelVersion = "6.2.1" ) -object CppProjectE2ETest : BazelBspE2ETestsBuildType( - targets = "//e2e:BazelBspCppProjectTest", +object BazelBspRemoteBazel5JdkTest : BazelBspE2ETestsBuildType( + targets = "//e2e:BazelBspRemoteJdkTest", + bazelVersion = "5.4.1" ) diff --git a/.teamcity/configurations/resultsAggregator.kts b/.teamcity/configurations/resultsAggregator.kts index 9b39604ff..471d07845 100644 --- a/.teamcity/configurations/resultsAggregator.kts +++ b/.teamcity/configurations/resultsAggregator.kts @@ -9,6 +9,8 @@ object BazelBspAggregator : BuildType({ name = "bazel-bsp results" + allowExternalStatus = true + vcs { root(BaseConfiguration.BazelBspVcs) showDependenciesChanges = false diff --git a/.teamcity/settings.kts b/.teamcity/settings.kts index d3d4b9489..5c8b597b9 100644 --- a/.teamcity/settings.kts +++ b/.teamcity/settings.kts @@ -1,6 +1,5 @@ import configurations.bazelBsp.* import configurations.* -import jetbrains.buildServer.configs.kotlin.v10.toExtId import jetbrains.buildServer.configs.kotlin.v2019_2.* import jetbrains.buildServer.configs.kotlin.v2019_2.triggers.vcs import jetbrains.buildServer.configs.kotlin.v2019_2.Project @@ -29,10 +28,12 @@ object BazelBsp : Project({ }) { buildType(BazelBuild.BuildTheProject) buildType(BazelUnitTests.UnitTests) - buildType(BazelE2eTests.SampleRepoE2ETest) - buildType(BazelE2eTests.BazelBspLocalJdkTest) - buildType(BazelE2eTests.BazelBspRemoteJdkTest) - buildType(BazelE2eTests.CppProjectE2ETest) + buildType(BazelE2eTests.SampleRepoBazel6E2ETest) + buildType(BazelE2eTests.SampleRepoBazel5E2ETest) + buildType(BazelE2eTests.BazelBspLocalBazel6JdkTest) + buildType(BazelE2eTests.BazelBspLocalBazel5JdkTest) + buildType(BazelE2eTests.BazelBspRemoteBazel6JdkTest) + buildType(BazelE2eTests.BazelBspRemoteBazel5JdkTest) } buildType(ResultsAggregator.BazelBspAggregator, options = { @@ -49,6 +50,7 @@ object BazelBsp : Project({ allSteps.last().triggers { vcs { branchFilter = """ + +: +:pull/* """.trimIndent() } @@ -59,10 +61,12 @@ object BazelBsp : Project({ RelativeId("FormatBuildifier"), RelativeId("BuildBuildBazelBsp"), RelativeId("UnitTestsUnitTests"), - RelativeId("E2eTestsE2eBazelBspSampleRepoTestTest"), - RelativeId("E2eTestsE2eBazelBspLocalJdkTestTest"), - RelativeId("E2eTestsE2eBazelBspRemoteJdkTestTest"), - RelativeId("E2eTestsE2eBazelBspCppProjectTestTest"), + RelativeId("E2eTestsE2eBazelBspSampleRepoTestTestWithBazel621"), + RelativeId("E2eTestsE2eBazelBspSampleRepoTestTestWithBazel541"), + RelativeId("E2eTestsE2eBazelBspLocalJdkTestTestWithBazel621"), + RelativeId("E2eTestsE2eBazelBspLocalJdkTestTestWithBazel541"), + RelativeId("E2eTestsE2eBazelBspRemoteJdkTestTestWithBazel621"), + RelativeId("E2eTestsE2eBazelBspRemoteJdkTestTestWithBazel541"), RelativeId("BazelBspResults") ) }) diff --git a/README.md b/README.md index a326cc15e..1b81623aa 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ [![JetBrains team project](http://jb.gg/badges/team.svg)](https://confluence.jetbrains.com/display/ALL/JetBrains+on+GitHub) +[![TeamCity build status](https://bazel.teamcity.com/app/rest/builds/buildType:id:Bazel_BazelBsp_BazelBspResults/statusIcon.svg)](https://bazel.teamcity.com/project/Bazel_BazelBsp?branch=%3Cdefault%3E&buildTypeTab=overview&mode=builds) [![Bazel Steward badge](https://img.shields.io/badge/Bazel_Steward-helping-blue.svg?style=flat&logo=)](https://github.com/VirtusLab/bazel-steward) - # Bazel BSP An implementation of the [Build Server Protocol](https://github.com/build-server-protocol/build-server-protocol) for