Skip to content

Commit

Permalink
Update the build scripts to handle dependency updates
Browse files Browse the repository at this point in the history
  • Loading branch information
ThisaruGuruge committed Dec 18, 2024
1 parent 7133423 commit 8ff45cc
Show file tree
Hide file tree
Showing 8 changed files with 172 additions and 65 deletions.
26 changes: 26 additions & 0 deletions build-config/resources/TransactionNegativeBallerina.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
[package]
org = "ballerinai"
name = "transaction_negative_tests"
version = "1.11.0"

[platform.java21]
graalvmCompatible = true

[[platform.java21.dependency]]
path = "../transaction-native/build/libs/[email protected]@.jar"
groupId = "ballerina"
artifactId = "transaction"
version = "@project.version@"

[[platform.java21.dependency]]
path = "../transaction-test-utils/build/libs/[email protected]@.jar"
groupId = "org.ballerinalang.stdlib.transaction"
scope = "testOnly"
artifactId = "transaction"
version = "@project.version@"

[[platform.java21.dependency]]
path = "./lib/[email protected]@.jar"
groupId = "io.ballerina.stdlib"
artifactId = "io-native"
version = "@stdlib.io.version@"
27 changes: 4 additions & 23 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -16,31 +16,12 @@
*/

plugins {
id "com.github.spotbugs" version "${spotbugsPluginVersion}"
id "com.github.johnrengelman.shadow" version "${shadowJarPluginVersion}"
id "de.undercouch.download" version "${downloadPluginVersion}"
id "net.researchgate.release" version "${releasePluginVersion}"
id "com.github.spotbugs"
id "com.github.johnrengelman.shadow"
id "de.undercouch.download"
id "net.researchgate.release"
}

ext.ballerinaLangVersion = project.ballerinaLangVersion
ext.checkStylePluginVersion = project.checkStylePluginVersion
ext.testngVersion = "7.6.1"
ext.slf4jVersion = "1.7.30"
ext.stdlibIoVersion = project.stdlibIoVersion
ext.stdlibOsVersion = project.stdlibOsVersion
ext.stdlibUuidVersion = project.stdlibUuidVersion
ext.stdlibHttpVersion = project.stdlibHttpVersion

ext.stdlibMimeVersion = project.stdlibMimeVersion
ext.stdlibLogVersion = project.stdlibLogVersion
ext.stdlibAuthVersion = project.stdlibAuthVersion
ext.stdlibCacheVersion = project.stdlibCacheVersion
ext.stdlibTimeVersion = project.stdlibTimeVersion
ext.stdlibFileVersion = project.stdlibFileVersion
ext.stdlibTaskVersion = project.stdlibTaskVersion
ext.stdlibJwtVersion = project.stdlibJwtVersion
ext.stdlibOAuth2Version = project.stdlibOAuth2Version

allprojects {
group = 'org.ballerinalang'
version = project.version
Expand Down
2 changes: 2 additions & 0 deletions gradle.properties
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@ shadowJarPluginVersion=8.1.1
downloadPluginVersion=5.4.0
releasePluginVersion=2.8.0
ballerinaGradlePluginVersion=2.0.1
testngVersion=7.6.1
slf4jVersion=1.7.30

# Level 01
stdlibIoVersion=1.7.0-20241218-111600-1da6a3f
Expand Down
20 changes: 20 additions & 0 deletions settings.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,26 @@
* in the user manual at https://docs.gradle.org/6.3/userguide/multi_project_builds.html
*/

pluginManagement {
plugins {
id "com.github.spotbugs" version "${spotbugsPluginVersion}"
id "com.github.johnrengelman.shadow" version "${shadowJarPluginVersion}"
id "de.undercouch.download" version "${downloadPluginVersion}"
id "net.researchgate.release" version "${releasePluginVersion}"
id "io.ballerina.plugin" version "${ballerinaGradlePluginVersion}"
}
repositories {
gradlePluginPortal()
maven {
url = 'https://maven.pkg.github.com/ballerina-platform/*'
credentials {
username System.getenv("packageUser")
password System.getenv("packagePAT")
}
}
}
}

plugins {
id "com.gradle.enterprise" version "3.13.2"
}
Expand Down
18 changes: 3 additions & 15 deletions transaction-ballerina/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -14,21 +14,11 @@
* limitations under the License.
*
*/

import org.apache.tools.ant.taskdefs.condition.Os

buildscript {
repositories {
maven {
url = 'https://maven.pkg.github.com/ballerina-platform/plugin-gradle'
credentials {
username System.getenv("packageUser")
password System.getenv("packagePAT")
}
}
}
dependencies {
classpath "io.ballerina:plugin-gradle:${project.ballerinaGradlePluginVersion}"
}
plugins {
id 'io.ballerina.plugin'
}

description = 'Ballerina - Transaction Ballerina Generator'
Expand All @@ -39,8 +29,6 @@ def tomlVersion = "0.0.0"
def ballerinaTomlFilePlaceHolder = new File("${project.rootDir}/build-config/resources/Ballerina.toml")
def ballerinaTomlFile = new File("$project.projectDir/Ballerina.toml")

apply plugin: 'io.ballerina.plugin'

ballerina {
packageOrganization = packageOrg
module = packageName
Expand Down
6 changes: 3 additions & 3 deletions transaction-negative-tests/Ballerina.toml
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ artifactId = "transaction"
version = "1.11.0-SNAPSHOT"

[[platform.java21.dependency]]
path = "./lib/io-native-1.7.0-20241209-171400-26de7d8.jar"
groupId = "org.ballerinalang"
path = "./lib/io-native-1.7.0-20241218-111600-1da6a3f.jar"
groupId = "io.ballerina.stdlib"
artifactId = "io-native"
version = "1.7.0-20241121-173300-0fbd5d4"
version = "1.7.0-20241218-111600-1da6a3f"
102 changes: 102 additions & 0 deletions transaction-negative-tests/Dependencies.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
# AUTO-GENERATED FILE. DO NOT MODIFY.

# This file is auto-generated by Ballerina for managing dependency versions.
# It should not be modified by hand.

[ballerina]
dependencies-toml-version = "2"
distribution-version = "2201.11.0-20241218-101200-109f6cc7"

[[package]]
org = "ballerina"
name = "io"
version = "1.7.0"
scope = "testOnly"
dependencies = [
{org = "ballerina", name = "jballerina.java"},
{org = "ballerina", name = "lang.value"}
]
modules = [
{org = "ballerina", packageName = "io", moduleName = "io"}
]

[[package]]
org = "ballerina"
name = "jballerina.java"
version = "0.0.0"
scope = "testOnly"
modules = [
{org = "ballerina", packageName = "jballerina.java", moduleName = "jballerina.java"}
]

[[package]]
org = "ballerina"
name = "lang.__internal"
version = "0.0.0"
scope = "testOnly"
dependencies = [
{org = "ballerina", name = "jballerina.java"},
{org = "ballerina", name = "lang.object"}
]

[[package]]
org = "ballerina"
name = "lang.array"
version = "0.0.0"
scope = "testOnly"
dependencies = [
{org = "ballerina", name = "jballerina.java"},
{org = "ballerina", name = "lang.__internal"}
]

[[package]]
org = "ballerina"
name = "lang.error"
version = "0.0.0"
scope = "testOnly"
dependencies = [
{org = "ballerina", name = "jballerina.java"}
]

[[package]]
org = "ballerina"
name = "lang.object"
version = "0.0.0"
scope = "testOnly"

[[package]]
org = "ballerina"
name = "lang.value"
version = "0.0.0"
scope = "testOnly"
dependencies = [
{org = "ballerina", name = "jballerina.java"}
]

[[package]]
org = "ballerina"
name = "test"
version = "0.0.0"
scope = "testOnly"
dependencies = [
{org = "ballerina", name = "jballerina.java"},
{org = "ballerina", name = "lang.array"},
{org = "ballerina", name = "lang.error"}
]
modules = [
{org = "ballerina", packageName = "test", moduleName = "test"}
]

[[package]]
org = "ballerinai"
name = "transaction_negative_tests"
version = "0.0.0"
dependencies = [
{org = "ballerina", name = "io"},
{org = "ballerina", name = "jballerina.java"},
{org = "ballerina", name = "test"}
]
modules = [
{org = "ballerinai", packageName = "transaction_negative_tests", moduleName = "transaction_negative_tests"}
]

36 changes: 12 additions & 24 deletions transaction-negative-tests/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -56,12 +56,10 @@ task copyToLib(type: Copy) {
}

def tomlVersion = stripBallerinaExtensionVersion("${project.version}")
def ballerinaConfigFile = new File("$project.projectDir/Ballerina.toml")
def ballerinaDependencyFile = new File("$project.projectDir/Dependencies.toml")
def configTOMLFile = new File("$project.projectDir/tests/Config.toml")
def originalConfig = ballerinaConfigFile.text
def originalDependencies = ballerinaDependencyFile.text
def initialTOMLcontent = configTOMLFile.text
def ballerinaTomlPlaceHolder = new File("${project.rootDir}/build-config/resources/TransactionNegativeBallerina.toml")
def ballerinaTomlFile = new File("${project.rootDir}/transaction-negative-tests/Ballerina.toml")
def configTomlFile = new File("$project.projectDir/tests/Config.toml")
def originalConfigFileText = configTomlFile.text
def graalvmFlag = ""
def testParams = "--code-coverage --includes=ballerinai.*:org.ballerinalang.stdlib.transaction.*"

Expand All @@ -88,32 +86,22 @@ def stripBallerinaExtensionVersion(String extVersion) {

task updateTomlVersions {
doLast {
def stdlibNativeIoVersion = project.stdlibIoVersion

def stdlibDependentIoVersion = stripBallerinaExtensionVersion(project.stdlibIoVersion)
def stdlibDependentOsVersion = stripBallerinaExtensionVersion(project.stdlibOsVersion)

def newConfig = ballerinaConfigFile.text.replace("@project.version@", project.version)
def newConfig = ballerinaTomlPlaceHolder.text.replace("@project.version@", project.version)
newConfig = newConfig.replace("@toml.version@", tomlVersion)
newConfig = newConfig.replace("@io.native.version@", stdlibNativeIoVersion)
ballerinaConfigFile.text = newConfig

def newDependencyConfig = ballerinaDependencyFile.text.replace("@stdlib.io.version@", stdlibDependentIoVersion)
newDependencyConfig = newDependencyConfig.replace("@stdlib.os.version@", stdlibDependentOsVersion)
ballerinaDependencyFile.text = newDependencyConfig
newConfig = newConfig.replace("@stdlib.io.version@", stdlibIoVersion)
ballerinaTomlFile.text = newConfig
}
}

task revertTomlFile {
doLast {
ballerinaConfigFile.text = originalConfig
configTOMLFile.text = initialTOMLcontent
ballerinaDependencyFile.text = originalDependencies
configTomlFile.text = originalConfigFileText
}
}

def setExecPath(configTOMLFile, distributionBinPath) {
configTOMLFile.text = configTOMLFile.text.replace("@exec.path@", distributionBinPath)
def setExecPath(configTomlFile, originalConfigFileText, distributionBinPath) {
def newConfig = originalConfigFileText.replace("@exec.path@", distributionBinPath)
configTomlFile.text = newConfig
}

task ballerinaNegativeTests {
Expand All @@ -132,7 +120,7 @@ task ballerinaNegativeTests {
doLast {
def distributionBinPath = "$project.rootDir/target/ballerina-runtime/bin"

setExecPath(configTOMLFile,distributionBinPath)
setExecPath(configTomlFile, originalConfigFileText, distributionBinPath)
exec {
workingDir project.projectDir
environment "JAVA_OPTS", "-DBALLERINA_DEV_COMPILE_BALLERINA_ORG=true"
Expand Down

0 comments on commit 8ff45cc

Please sign in to comment.