Gradle - Manajemen Ketergantungan
Skrip build Gradle mendefinisikan proses untuk membangun proyek; setiap proyek berisi beberapa dependensi dan beberapa publikasi. Dependensi berarti hal-hal yang mendukung untuk membangun proyek Anda seperti file JAR yang diperlukan dari proyek lain dan JAR eksternal seperti JDBC JAR atau Eh-cache JAR di jalur kelas. Publikasi berarti hasil dari proyek, seperti file kelas pengujian dan file build, seperti file perang.
Hampir semua proyek tidak berdiri sendiri. Mereka membutuhkan file yang dibangun oleh proyek lain untuk mengompilasi dan menguji file sumber. Misalnya, untuk menggunakan Hibernate dalam proyek ini, Anda perlu menyertakan beberapa JAR Hibernasi di jalur kelas. Gradle menggunakan beberapa skrip khusus untuk menentukan dependensi, yang perlu diunduh.
Gradle menangani pembuatan dan penerbitan hasilnya di suatu tempat. Penerbitan didasarkan pada tugas yang Anda tentukan. Ini mungkin ingin menyalin file ke direktori lokal, atau mengunggahnya ke Maven jarak jauh atau repositori lvy atau Anda mungkin menggunakan file dari proyek lain dalam multi-proyek build yang sama. Kita bisa menyebut proses penerbitan tugas adalah publikasi.
Menyatakan Ketergantungan Anda
Konfigurasi ketergantungan tidak lain adalah mendefinisikan sekumpulan ketergantungan. Anda dapat menggunakan fitur ini untuk mendeklarasikan sarana ketergantungan eksternal yang ingin Anda unduh dari web. Ini mendefinisikan standart berbeda seperti berikut.
apply plugin: 'java'
repositories {
mavenCentral()
}
dependencies {
compile group: 'org.hibernate', name: 'hibernate-core', version: '3.6.7.Final'
testCompile group: 'junit', name: 'junit', version: '4.+'
}
Konfigurasi Ketergantungan
Konfigurasi dependensi tidak lain adalah mendefinisikan sekumpulan dependensi. Anda dapat menggunakan fitur ini untuk mendeklarasikan dependensi eksternal, yang ingin Anda download dari web. Ini mendefinisikan konfigurasi standar yang berbeda berikut ini.
Compile - Ketergantungan yang diperlukan untuk menyusun sumber produksi proyek.
Runtime- Dependensi yang diperlukan oleh kelas produksi pada waktu proses. Secara default, juga menyertakan dependensi waktu kompilasi.
Test Compile- Ketergantungan yang diperlukan untuk mengompilasi sumber pengujian proyek. Secara default, ini menyertakan kelas produksi yang dikompilasi dan dependensi waktu kompilasi.
Test Runtime- Ketergantungan yang diperlukan untuk menjalankan tes. Secara default, ini menyertakan runtime dan uji kompilasi dependensi.
Dependensi Eksternal
Dependensi eksternal adalah salah satu jenis dependensi. Ini adalah ketergantungan pada beberapa file yang dibangun di luar pada build saat ini, dan disimpan dalam beberapa jenis repositori, seperti Maven central, atau Maven perusahaan atau repositori lvy, atau direktori I sistem file lokal.
Potongan kode berikut adalah untuk menentukan ketergantungan eksternal. Gunakan kode ini dibuild.gradle mengajukan.
dependencies {
compile group: 'org.hibernate', name: 'hibernate-core', version: '3.6.7.Final'
}
Ketergantungan eksternal mendeklarasikan ketergantungan eksternal dan formulir pintasan terlihat seperti "group: name: version".
Repositori
Sambil menambahkan dependensi eksternal. Gradle mencarinya di repositori. Repositori hanyalah kumpulan file, diatur berdasarkan grup, nama dan versi. Secara default, Gradle tidak mendefinisikan repositori apa pun. Kami harus mendefinisikan setidaknya satu repositori secara eksplisit. Potongan kode berikut menjelaskan bagaimana mendefinisikan repositori maven. Gunakan kode ini dibuild.gradle mengajukan.
repositories {
mavenCentral()
}
Kode berikut adalah untuk mendefinisikan maven jauh. Gunakan kode ini dibuild.gradle mengajukan.
repositories {
maven {
url "http://repo.mycompany.com/maven2"
}
}
Penerbitan Artefak
Konfigurasi ketergantungan juga digunakan untuk menerbitkan file. File yang dipublikasikan ini disebut artefak. Biasanya, kami menggunakan plugin untuk menentukan artefak. Namun, Anda perlu memberi tahu Gradle tempat memublikasikan artefak tersebut. Anda dapat melakukannya dengan melampirkan repositori ke tugas arsip unggah. Lihatlah sintaks berikut untuk menerbitkan repositori Maven. Saat menjalankan, Gradle akan menghasilkan dan mengupload Pom.xml sesuai persyaratan proyek. Gunakan kode ini dibuild.gradle mengajukan.
apply plugin: 'maven'
uploadArchives {
repositories {
mavenDeployer {
repository(url: "file://localhost/tmp/myRepo/")
}
}
}