前言
iceberg本地编译。
一、下载
git clone https://github.com/apache/iceberg.git
二、编辑gradle文件,添加国内源
在buildscript的repositories中添加
maven{ url 'https://mirrors.huaweicloud.com/repository/maven/' }
添加后如下所示:
buildscript {
repositories {
maven{ url 'https://mirrors.huaweicloud.com/repository/maven/' }
gradlePluginPortal()
}
dependencies {
classpath 'com.github.jengelman.gradle.plugins:shadow:5.0.0'
classpath 'com.palantir.baseline:gradle-baseline-java:3.36.2'
classpath 'com.palantir.gradle.gitversion:gradle-git-version:0.12.3'
classpath 'com.diffplug.spotless:spotless-plugin-gradle:5.14.0'
classpath 'gradle.plugin.org.inferred:gradle-processors:2.1.0'
classpath 'me.champeau.gradle:jmh-gradle-plugin:0.4.8'
}
}
allprojects中添加
maven {
url 'https://mirrors.huaweicloud.com/repository/maven/'
}
添加后如下所示
allprojects {
group = "org.apache.iceberg"
version = getProjectVersion()
repositories {
maven {
url 'https://mirrors.huaweicloud.com/repository/maven/'
}
mavenCentral()
mavenLocal()
}
project.ext {
Spark30Version = '3.0.3'
Spark31Version = '3.1.1'
}
}
下载依赖(可选) 进入项目根目录,执行脚本:
./gradlew dependencies
三、正式编译
进入项目根目录,执行:
./gradlew build
上述命令会执行代码里的单元测试,如果不需要,则执行以下命令:
./gradlew build -x test
解释: 在gradle中,如果要跳过某个task,就可以添加–exclude-task参数(短命令便是-x),跟上task名称,在很多项目中,单元测试是以test命名的。
如果在执行的过程中,发现并没有跳过所有测试,是因为在iceberg里面,有些测试并没有以test命名,比如关于spark的单元测试,有些被命名为testSpark31,所以需要将此也一并跳过,此时,只需要在命令后面追加 -x testSpark31即可,如果有别的测试,像这样添加进去即可。 测试相关task时可按下方示例:
task testSpark31(type: Test) {
dependsOn classes
group = "verification"
description = "Test against Spark 3.1"
testClassesDirs = sourceSets.spark31.output.classesDirs
classpath = sourceSets.spark31.runtimeClasspath + sourceSets.main.output
}
关于代码格式检查,如果在编译过程中,需要跳过代码格式检查,可以添加:
-x scalaStyle 跳过scala代码检查
|