Я хочу дать вам четкое представление. По этой причине я прилагаю код снимка build.grade для лучшего понимания.
зависимости buildscript:
buildscript {
repositories {
maven { url("https://plugins.gradle.org/m2/") }
}
dependencies {
classpath 'net.saliman:gradle-cobertura-plugin:2.3.2'
classpath 'com.netflix.nebula:gradle-lint-plugin:latest.release'
}
}
корень / основной уровень зависимости:
repositories{
mavenLocal()
maven { url("https://plugins.gradle.org/m2/") }
maven { url "https://repo.spring.io/snapshot" }
}
dependencies {
//Groovy
compile group: 'org.codehaus.groovy', name: 'groovy-all', version: '2.3.10'
//Spock Test
compile group: 'org.spockframework', name: 'spock-core', version: '1.0-groovy-2.3'
//Test
testCompile group: 'junit', name: 'junit', version: '4.10'
testCompile group: 'org.testng', name: 'testng', version: '6.8.5'
}
Итак, сначала я хочу уточнить одним словом, что
i) файл jar зависимостей buildscript будет загружен из репозиториев buildscript. [Внешняя зависимость проекта]
ii) файл jar зависимостей корневого уровня будет загружен из хранилищ корневого уровня. [Для зависимости проекта]
Вот,
Блок «buildscript» управляет только зависимостями для самого процесса buildscript, а не для кода приложения. Как различный плагин Gradle gradle-cobertura-plugin
, gradle-lint-plugin
можно найти в репозиториях buildscript. Эти плагины не будут ссылаться как зависимости для кода приложения.
Но для компиляции проекта и запуска теста jar-файлы, такие как groovy all jar, junit and testng jar
будут найдены в репозиториях корневого уровня.
И еще , maven { url("https://plugins.gradle.org/m2/") }
порция может быть использована в обоих блоках. Потому что они используются для разных зависимостей.
Ссылка на ресурс: Разница между зависимостями в закрытии buildscript и ядром