Untuk memberikan dukungan sintaksis saat membuat alur kerja, Anda dapat menggunakan skema JSON Alur Kerja di lingkungan pengembangan terintegrasi (IDE) seperti Visual Studio Code (VS Code) atau Intellij IDEA. Dukungan sintaksis mencakup pelengkapan otomatis, validasi, dan dokumentasi inline. Skema juga dapat diintegrasikan ke dalam proses CI/CD Anda.
Skema JSON Alur Kerja ditulis dalam JSON Schema, bahasa deklaratif yang memungkinkan Anda menganotasi dan memvalidasi dokumen JSON. Sumber skema dihosting di SchemaStore.org, repositori skema untuk file konfigurasi berbasis JSON umum. Perhatikan bahwa skema dari SchemaStore.org juga dapat diterapkan ke file YAML.
Bergantung pada IDE atau editor yang ingin Anda gunakan, Anda dapat menginstal plugin atau menerapkan dukungan bawaan untuk menggunakan skema Alur Kerja. Skema dapat disimpan secara lokal di root project Anda atau dapat ditentukan melalui URL resource-nya di SchemaStore.org.
Format nama file untuk file definisi alur kerja
Terlepas dari IDE atau editor yang Anda gunakan, jika Anda menggunakan plugin atau ekstensi untuk menerapkan skema Alur Kerja secara otomatis dari SchemaStore.org, format nama file untuk file definisi alur kerja Anda harus sebagai berikut:
workflows.json
workflows.yaml
workflows.yml
*.workflows.json
*.workflows.yaml
*.workflows.yml
Jika menggunakan VS Code, atau jika menggunakan dukungan bawaan untuk menerapkan skema Alur Kerja, Anda dapat mengganti format nama file.
Batasan
Dukungan sintaksis melalui skema JSON Alur Kerja berfokus pada pelengkapan otomatis kata kunci yang menentukan alur kerja. Skema mendukung pelengkapan otomatis untuk beberapa fungsi library standar, tetapi dukungan terbatas untuk nama variabel dinamis, ekspresi, dan bantuan ekspresi lainnya. Skema ini juga mengasumsikan bahwa alur kerja sudah selesai dan tidak memperhitungkan pascapemrosesan apa pun seperti penggabungan subalur kerja.
Untuk menghindari konflik skema JSON, sebaiknya jangan gunakan lebih dari satu ekstensi atau plugin untuk dukungan sintaksis Alur Kerja.
Mengaitkan skema JSON Workflows di VS Code
VS Code adalah editor kode sumber yang berjalan di desktop Anda dan tersedia untuk Windows, macOS, dan Linux. Library ini dilengkapi dengan dukungan bawaan untuk beberapa bahasa dan mendukung ekstensi untuk bahasa dan runtime lainnya. Untuk menginstal dan menyiapkan VS Code di komputer Anda, lihat Visual Studio Code.
Berikut adalah berbagai cara untuk mengaitkan skema JSON Alur Kerja di VS Code.
Menggunakan Cloud Code untuk membuat alur kerja dalam YAML
Cloud Code adalah serangkaian plugin IDE yang mempermudah pembuatan, deployment, dan integrasi aplikasi dengan Google Cloud.
Jika menggunakan VS Code sebagai IDE, Anda dapat menggunakan Cloud Code saat menulis alur kerja YAML dan kode tersebut akan otomatis mengambil skema JSON Alur Kerja dari SchemaStore.org. Untuk mengonfirmasi bahwa skema diterapkan seperti yang diharapkan, buat alur kerja YAML di ruang kerja atau folder VS Code, dan konfirmasi bahwa pelengkapan otomatis terjadi untuk kata kunci Alur Kerja.
Cloud Code juga mendukung skema Google Cloud offline, dan dapat digunakan oleh pengguna yang mungkin memiliki batasan jaringan atau IDE. Untuk informasi selengkapnya, lihat referensi berikut:
- Menginstal ekstensi Cloud Code for VS Code
- Menggunakan YAML di Cloud Code for VS Code
- Pelajari Cloud Code for VS Code lebih lanjut
Menggunakan YAML oleh RedHat untuk membuat alur kerja dalam YAML
Sebagai alternatif untuk menggunakan ekstensi Cloud Code untuk VS Code, Anda dapat menggunakan ekstensi YAML oleh RedHat. Ekstensi ini menyediakan dukungan bahasa YAML dan menyertakan dukungan sintaksis Kubernetes bawaan. Alat ini otomatis mengambil skema JSON Alur Kerja dari SchemaStore.org.
Setelah menginstal ekstensi, buat alur kerja YAML. Di bagian atas file, harus ada link file konfigurasi Google Cloud Workflows (workflows.json). Jika Anda mengklik link, skema JSON Alur Kerja akan terbuka di editor VS Code.
Mengganti format nama file
Saat menggunakan Cloud Code atau YAML oleh RedHat untuk membuat alur kerja dalam YAML,
Anda dapat mengganti format nama file default yang digunakan untuk menerapkan skema
Alur Kerja. Anda harus menentukan pemetaan dalam file settings.json
. Setelan ditulis sebagai JSON dan Anda dapat meninjau serta mengedit file ini langsung dengan membukanya di editor VS Code.
Misalnya, jika menggunakan ekstensi Cloud Code for VS Code, Anda dapat memetakan format nama file di bagian properti cloudcode.yaml.schemas
:
{ "cloudcode.yaml.schemas": { "https://json.schemastore.org/workflows.json": [ "GLOB_PATTERN.yaml", "my-special-workflow.yaml" ] } }
Atau, jika Anda menggunakan ekstensi YAML oleh RedHat, petakan format nama file di bagian
yaml.schemas
properti:
{ "yaml.schemas": { "https://json.schemastore.org/workflows.json": [ "GLOB_PATTERN.yaml", "my-special-workflow.yaml" ] } }
Skema di sebelah kiri diterapkan ke pola glob di sebelah kanan; setiap skema dikaitkan dengan beberapa glob menggunakan array JSON. Skema Anda harus berupa jalur relatif, bukan jalur absolut. Skema Anda dapat bersifat lokal atau online.
Menggunakan dukungan bawaan untuk membuat alur kerja dalam JSON
Anda dapat menggunakan dukungan bawaan di VS Code untuk mengaitkan skema JSON
Alur Kerja dengan menentukan pemetaan dalam file settings.json
, di bagian
properti json.schemas
. Anda dapat meninjau dan mengedit file ini secara langsung dengan
membukanya di editor VS Code.
Misalnya, untuk mengambil skema JSON Alur Kerja dari SchemaStore.org:
{ "json.schemas": [ { "description": "SchemaStore.org", "fileMatch": [ "workflows.json", "*.workflows.json" ], "url": "https://json.schemastore.org/workflows.json" } ] }
Skema di sebelah kiri diterapkan ke pola glob di sebelah kanan; skema dikaitkan dengan beberapa glob menggunakan array JSON. Skema Anda harus berupa jalur relatif, bukan jalur absolut. Skema Anda dapat bersifat lokal atau online.
Anda dapat mengganti format nama file. Contoh:
{ "json.schemas": [ { "description": "Workflows schema", "fileMatch": [ "GLOB_PATTERN.json", "FILE_NAME.json" ], "url": "https://json.schemastore.org/workflows.json" } ] }
Untuk mengetahui informasi selengkapnya, lihat Mengedit JSON dengan Visual Studio Code.
Mengaitkan skema JSON Workflows di IntelliJ IDEA
IntelliJ IDEA adalah IDE lintas platform untuk bahasa Java Virtual Machine. Bahasa lainnya didukung melalui plugin. Untuk menginstal dan menyiapkan IntelliJ IDEA di komputer, lihat Menginstal IntelliJ IDEA.
Berikut adalah berbagai cara untuk mengaitkan skema JSON Workflows di IntelliJ IDEA.
Menggunakan Cloud Code untuk membuat alur kerja dalam YAML atau JSON
Cloud Code adalah serangkaian plugin IDE yang mempermudah pembuatan, deployment, dan integrasi aplikasi dengan Google Cloud.
Jika menggunakan IntelliJ sebagai IDE, Anda dapat menggunakan Cloud Code saat menulis alur kerja dalam YAML atau JSON dan kode tersebut akan otomatis mengambil skema JSON Alur Kerja dari SchemaStore.org. Cloud Code juga mendukung skema Google Cloud offline, dan dapat digunakan oleh pengguna yang mungkin memiliki batasan jaringan atau IDE. Untuk informasi selengkapnya, lihat referensi berikut:
- Menginstal plugin Cloud Code for IntelliJ
- Menggunakan YAML di Cloud Code for IntelliJ
- Pelajari Cloud Code for IntelliJ lebih lanjut
Menggunakan dukungan bawaan untuk membuat alur kerja dalam YAML atau JSON
IntelliJ IDEA dapat otomatis mendownload dan menggunakan skema dari SchemaStore.org. Anda dapat mendownload skema JSON Workflows dan menyimpannya di root project atau menentukan URL resource sehingga IntelliJ IDEA dapat mendownload skema secara otomatis. Untuk memetakan skema, ikuti petunjuk untuk mengonfigurasi skema JSON kustom.
Secara default, download otomatis skema dari SchemaStore.org diaktifkan dan pola nama file default divalidasi terhadap skema.
Untuk mengganti pola file default, setelah membuka JSON Schema Mappings melalui dialog Settings, lakukan hal berikut:
- Di kolom Name, ketik Workflows schema.
- Di kolom Schema file or URL, ketik https://json.schemastore.org/workflows.json.
- Dalam daftar Versi skema, pilih JSON Schema versi 7.
- Tambahkan Pola jalur file pilihan Anda.
Memetakan skema melalui jsonSchema.xml
Kode sumber IntelliJ IDEA Community Edition tersedia melalui https://github.com/JetBrains/intellij-community.
Anda dapat memetakan skema JSON Alur Kerja untuk editor IntelliJ IDEA dengan menambahkan entri ke jsonSchemas.xml.
Menambahkan validasi sintaksis Alur Kerja ke proses CI/CD
Menambahkan validasi sintaksis ke proses continuous integration, delivery, dan deployment (CI/CD) membantu mengurangi error selama integrasi, pengujian, pengiriman, dan deployment.
Misalnya, Anda dapat memvalidasi data berdasarkan skema JSON Alur Kerja menggunakan alat ajv-cli. Perhatikan bahwa saat menginstal alat ini, instal juga ajv-formats. Contoh:
npm install -g ajv-cli ajv-formats
Alat lain yang mungkin berguna:
- MegaLinter v8r—MegaLinter adalah alat open source untuk alur kerja CI/CD; v8r memeriksa validitas file JSON/YAML jika memiliki skema yang cocok yang ditentukan di SchemaStore.org.
- Validator JSON—Alat validasi JSON yang dikategorikan menurut bahasa pemrograman atau platform pengembangan.
Langkah selanjutnya
- Google Cloud Blog: Alur kerja mendapatkan Skema JSON yang diperbarui