Prompt Engineering untuk Data Sintetis

Menggunakan LLM untuk membuat data sintetis adalah strategi populer bagi tim QA. Anda dapat menghasilkan ratusan rekaman kompleks dalam hitungan detik.

Namun, prompt yang generik akan menjebak Anda. Jika Anda meminta LLM untuk "menghasilkan 50 pengguna uji", ia akan memberikan data yang dapat diprediksi dan repetitif. Hal ini menciptakan rasa cakupan (coverage) yang semu. Anda mendapatkan banyak rekaman yang hanya menguji "happy path" namun melewatkan edge case dan logika bisnis yang kritis.

Untuk memperbaikinya, Anda harus beralih dari sekadar peminta (requester) menjadi seorang pengatur (orchestrator). Anda perlu menerapkan prinsip-prinsip pengujian secara langsung ke dalam prompt engineering Anda.

Gunakan tiga pola ini untuk meningkatkan kualitas data Anda:

  1. Equivalence Partitioning dan Boundary Value Analysis Alih-alih meminta data, paksa LLM untuk memetakan kelas pengujian terlebih dahulu. Gunakan prompting Chain-of-Thought.

Ini memastikan Anda menguji titik transisi yang tepat, seperti $99,99 vs $100,00, tanpa membuang ruang untuk rekaman yang redundan.

  1. State Transition Testing Untuk sistem seperti alur pembayaran atau manajemen pesanan, data harus mencerminkan berbagai tahapan dalam sebuah siklus hidup (lifecycle).

Ini mencegah rekaman duplikat dan memaksa pembuatan negative test cases.

  1. Variance Control dan Negative Prompting LLM sering kali menghasilkan data yang homogen, seperti menggunakan wilayah atau kelompok usia yang sama. Gunakan Negative Prompting untuk menghentikan hal ini.

Ini menghilangkan bias dan memastikan backend Anda menangani data yang beragam dan realistis.

Kecepatan AI hanya akan memberikan nilai jika data Anda memiliki tujuan yang jelas. Peran Anda sebagai profesional QA adalah menyusun kode untuk batasan-batasan yang mengatur model generatif ini.

Sumber: https://dev.to/lopesdoamaral/engenharia-de-prompts-para-massa-de-dados-escalando-testes-com-cobertura-e-sem-duplicidade-oba

Komunitas belajar opsional: https://t.me/GyaanSetuAi