Konkordion - Perintah verifikasiRows

Perintah verifikasiRows Concordion dapat digunakan untuk memeriksa konten koleksi yang dikembalikan sebagai hasil oleh sistem. Misalnya, jika kita menyiapkan sekumpulan pengguna dalam sistem dan melakukan pencarian parsial pada mereka, maka sistem harus mengembalikan elemen yang cocok, jika tidak, pengujian penerimaan kita akan gagal.

Pertimbangkan persyaratan berikut -

<table>
   <tr><th>Users</th></tr>
   <tr><td>Robert De</td></tr>
   <tr><td>John Diere</td></tr>
   <tr><td>Julie Re</td></tr>
</table>

<p>Search for J should return:</p>

<table>
   <tr><th>Matching Users</th></tr>
   <tr><td>John Diere</td></tr>
   <tr><td>Julie Re</td></tr>
</table>

Jika kita ingin menulis spesifikasi untuk fungsi pencarian yang akan mencari dan mengembalikan koleksi, maka spesifikasinya adalah sebagai berikut -

<table concordion:execute = "addUser(#username)">
   <tr><th concordion:set = "#username">Username</th></tr>
   <tr><td>Robert De</td></tr>
   <tr><td>John Diere</td></tr>
   <tr><td>Julie Re</td></tr>
</table>

<p>Search for "<b concordion:set = "#searchString">J</b>" should return:</p>

<table concordion:verifyRows = "#username : search(#searchString)">
   <tr><th concordion:assertEquals = "#username">Matching Usernames</th></tr>
   <tr><td>John Diere</td></tr>
   <tr><td>Julie Re</td></tr>
</table>

Ketika Concordion mem-parsing dokumen, itu akan mengeksekusi addUser () pada setiap baris dari tabel pertama dan kemudian mengatur searchString menjadi J. Selanjutnya, Concordion akan menjalankan fungsi pencarian yang seharusnya mengembalikan objek Iterable dengan urutan iterasi yang dapat diprediksi, (mis. a List, LinkedHashSet atau TreeSet), verifikasiRows berjalan untuk setiap item dari koleksi dan menjalankan perintah assertEquals.

Contoh

Mari kita memiliki IDE Eclipse yang berfungsi dan ikuti langkah-langkah yang diberikan di bawah ini untuk membuat aplikasi Concordion -

Langkah Deskripsi
1 Buat proyek dengan konkordeon nama dan buat paket com.tutorialspoint di bawahsrc folder dalam proyek yang dibuat.
2 Tambahkan library Concordion yang diperlukan menggunakan opsi Add External JARs seperti yang dijelaskan dalam bab Concordion - First Application .
3 Buat Sistem kelas Java di bawah paket com.tutorialspoint .
4 Buat kelas Fixture SystemFixture di bawah paket specs.tutorialspoint .
5 Buat Spesifikasi html System.html di bawah paket specs.tutorialspoint .
6 Langkah terakhir adalah membuat konten dari semua file Java dan file spesifikasi dan menjalankan aplikasi seperti yang dijelaskan di bawah ini.

Berikut adalah konten file System.java -

package com.tutorialspoint;

import java.util.HashSet;
import java.util.Set;
import java.util.SortedSet;
import java.util.TreeSet;

public class System { 
   private Set<String> users = new HashSet<String>();
	
   public void addUser(String username) {
      users.add(username);
   }
	
   public Iterable<String> search(String searchString) {
      SortedSet<String> matches = new TreeSet<String>();
		
      for (String username : users) {
         if (username.contains(searchString)) {
            matches.add(username);
         }
      }
		
      return matches;
   }
}

Berikut adalah konten file SystemFixture.java -

package specs.tutorialspoint;

import org.concordion.integration.junit4.ConcordionRunner;
import org.junit.runner.RunWith;
import com.tutorialspoint.System;

@RunWith(ConcordionRunner.class)

public class SystemFixture {
   System system = new System();
   public void addUser(String username) {
      system.addUser(username);
   }
	
   public Iterable<String> search(String searchString) {
      return system.search(searchString);
   }
}

Berikut adalah konten file System.html -

<html xmlns:concordion = "http://www.concordion.org/2007/concordion">
   <head>
      <link href = "../concordion.css" rel = "stylesheet" type = "text/css" />
   </head>

   <body>
      <h1>System Specifications</h1>
      <p>We are building specifications for our online order tracking application.</p>
      <p>Following is the requirement to add a partial search capability on user names:</p>
		
      <div class = "example">      
         <h3>Example</h3>
			
         <table concordion:execute = "addUser(#username)">
            <tr><th concordion:set = "#username">Username</th></tr>
            <tr><td>Robert De</td></tr>
            <tr><td>John Diere</td></tr>
            <tr><td>Julie Re</td></tr>
         </table>
			
         <p>Search for "<b concordion:set = "#searchString">J</b>" should return:</p>
			
         <table concordion:verifyRows = "#username : search(#searchString)">
            <tr><th concordion:assertEquals = "#username">Matching Usernames</th></tr>
            <tr><td>John Diere</td></tr>
            <tr><td>Julie Re</td></tr>
         </table>
			
      </div> 
		
   </body>

</html>

Setelah Anda selesai membuat file sumber dan spesifikasi, mari kita jalankan aplikasi sebagai JUnit Test. Jika semuanya baik-baik saja dengan aplikasi Anda, maka itu akan menghasilkan hasil sebagai berikut -

C:\DOCUME~1\ADMINI~1\LOCALS~1\Temp\concordion\specs\tutorialspoint\System.html
Successes: 2, Failures: 0

System.html adalah output dari uji coba Concordion.