16 Ağustos 2016 Salı

Birim Test ve JUnit Kullanımı

Herkese merhaba, bu yazımda Birim Test ve Java'nın bir kütüphanesi olan JUnit'den bahsedeceğim. Yazının içeriğine alt başlıklar halinde şöyle bir bakacak olursak;

Birim Test nedir?
Yazılım Projesinde Birim Test'in Önemi nedir?
JUnit nedir? - Junit'de kullanılan assertion / annotation kavramları nelerdir?
Eclips'de JUnit oluşturulması ve çalıştırılması nasıl olur?

    Birim Test
En basit anlamda projemizdeki fonksiyonların çalışıp çalışmadığını kontrol eder. Birden fazla birim testimiz olabilir fakat hepsi birbirinden bağımsız çalışmalıdır. Yani her test için odaklanılan tek nokta vardır. Testler sonuç olarak bize true / false döndürürler.
Birim Test hataları bulmak için kullanılmaz, bizim verdiğimiz girdiler ile fonksiyonun çalışırlığını kontrol eder.
Projemizde kaç tane fonksiyon varsa o kadar test olmalıdır.
Birim Test nedir? sorusuna cevap bulduktan sonra şimdi neden kullanılıra gelelim;

    Yazılım Projesinde Birim Test'in Önemi nedir?
Bize kaliteli kod yazmamızı sağlar. Projeyi geliştirme esnasında yanlışlarımızı görmemizi sağlar. Bütün bileşenleri birbirinden bağımsız bir biçimde tasarlamış oluruz. Böylelikle bakımı daha kolay ve kaliteli bir yazılım ortaya çıkar.
Şimdi Java'da test olayına bakalım;

    JUnit nedir? - Junit'de kullanılan assertion / annotation kavramları nelerdir?
Projemizde bulunan fonksiyonların doğru çıktı verip vermediğini kontrol etmemize yarayan Java kütüphanesidir. Testimizin çalışabilmesi için öncesinde ve sonrasında olması gereken işlemler olabilir. Örnek olarak test edeceğimiz fonksiyonun çalışabilmesi için bir veritabanı bağlantısı gerekiyorsa bunu testten önce sağlamamız gerekir. Böyle durumlarda annotation kullanırız. Testlerde kullanılan annotation'lara bakarsak;

@Test :  Metodun test edileceğini gösterir
@Test(expected = Exception.class) :  Metod hata fırlatmalıdır
@Before : Metodtan önce çalışır.
@After :  Metodtan sonra çalışır
@BeforeClass : Sınıf instance olduğunda bir defalığına çalışır
@AfterClass :  Metodları test ettikten sonra çalışır
@Ignore : Test edilmesini istemediğimiz metodları temsil eder

Test ettiğimiz fonksiyonların dönüş değerlerine göre durum karşılaştırmaları yaptığımız assertionlar vardır.
Bunların kullanımına bakacak olursak;

public class OrnekTest{
 
 @Test
 public void tabikiTest(){
  String name = "Kerem";
  assertEquals(name, OrnekSinif.getPersonName());
 }
}

OrnekSinif(nasıl bir sınıf ismiyse :D )'ın getPersonName() fonksiyonundan dönen isim ile bizim oluşturduğumuz ismi karşılaştırıyoruz.
assertEquals() metodu bu iki değer doğruysa test sonucunu true olarak döndürecektir.
Birçok assertion bulunmaktadır bunların tam listesi.

Şimdi artık Eclips'te bir JUnit oluşturup, çalıştırmaya bir bakalım:

✖ Öncelikle projemize JUnit bağımlılıklarını ekliyoruz.

<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.12</version>
</dependency>

✖  New → Other  JUnit → JUnit Test Case 
Daha sonra testimizin ismini belirleyip Finish diyoruz.

import org.junit.Test;


public class TestOrnek {

 @Test
 public void test() {
  fail("Not yet implemented");
 }
}

Oluşan testimizin içeriği böyle oluyor.
Burada @Test kısmına girdileri verip sonuçların doğruluğunun kontrolünü yaparız.

Şimdi bu testimize örnek bir uygulama yapalım.

import static org.junit.Assert.*;
import org.junit.Test;

public class TestOrnek {
 public int topla(int x, int y){
  int sonuc = 0;
  sonuc = x + y;
  return sonuc;
 }
 @Test
 public void test() {
  int sonuc=0;
  sonuc = topla(5, 10);
  assertEquals(15, sonuc);
 }
}

Burada eğer topla fonksiyonumuzun sonucu 15 ise testimiz true olarak dönüş yapacaktır.


Testimizin çalışırlığını böylece kontrol etmiş oluruz.
İyi çalışmalar.

4 Ağustos 2016 Perşembe

Bootstrap Kullanarak Form Oluşturmak

Herkese merhaba, web kütüphanelerinden biri olan Bootstrap ile girilen bir json formatını kullanarak form oluşturmaktan bahsedeceğim.

Öncelikle Bootstrap'in ne olduğu hakkında bir şeyler söyleyecek olursam;

Bootstrap; HTML, CSS ve JS'i bir arada bulunduran ve bunları kullanarak web arayüzü geliştirebildiğimiz bir kütüphanedir.
CSS'e ek olarak CSS önişlemcisi olan Less ve Sass'ı kullanır.

Bootstrap açık kaynaklı bir kütüphanedir. Github projesine buradan bakabilirsiniz.

Bootstrap sayfasında birçok uygulayabileceğimiz örnekler bulunmaktadır.

Şimdi bir json girdisine karşılık gelen formumuzu oluşturalım.

1-) İlk adım olarak formumuzda hangi alanların oluşmasını istiyorsak o alanları json formatında javascript kodumuzun içerisinde belirtiyoruz.
var fields, form;

fields = [ 
    {
        name: 'username',
        label: 'Username',
        type: 'text'
    }, {
        name: 'password',
        label: 'Password',
        type: 'password'
    }, {
        name: 'fruit',
        label: 'Fruit',
        choices: [
            ['apple', 'Apple'],
            ['pear', 'Pear'],
            ['orange', 'Orange']
        ],
        type: 'selectmultiple2' 
     }, {
        label: 'Submit',
        type: 'submit',
        class: 'btn-danger',
        icon: 'ok'
    }];

2-) Daha sonra bu json girdisini alıp alanlarıyla form oluşturabileceğimiz formata çeviriyoruz.

fields = JSON.stringify(fields);
        fields = formatter.formatjson(fields);
        demoInput = $('#form-demo-input');
        demoInput.val(fields);
          
        outputForm = $('#form-demo-output');
        outputForm.submit(function() {return false});
Bu işlemleri gerçekleştirdiğimizde formumuz şekildeki gibi oluşur;


Kodun tamamı ve uyguladığım örneğe linkten ulaşabilirsiniz.
İyi çalışmalar ve kolaylıklar dilerim.

1 Ağustos 2016 Pazartesi

Rest Api'yi Swagger Uyumlu Hale Getirmek

Herkese merhaba, bu yazımda bir Rest Apinin Swagger uyumlu hale getirilmesindeki adımlardan bahsedeceğim. Neleri eklememiz gerektiğinden, hangi özellikler için hangi metodları kullandığımızdan bahsedeceğim.

*Swagger-UI: 
Bir bağımlılığa sahip değildir, kendi yerel makinemizde çalıştırabiliriz. Apinin swagger uyumlu hale geldikten sonraki görüntüsüne örnek olarak petstore uygulaması verilebilir.

Şimdi apiyi swagger uyumlu hale getirmek için izlenecek adımları sırayla uygulamaya başlayalım.

1-)Öncelikle apimizde bulunan pom.xml dosyasının içine gereken bağımlılıkları ekliyoruz.

<dependency>
    <groupId>io.swagger</groupId>
    <artifactId>swagger-jaxrs</artifactId>
    <version>${swagger-version}</version>
    <scope>compile</scope>
</dependency>
2-) Daha sonra buradan Swagger-ui paketini indiriyoruz.

-> Bu indirdiğimiz paketin içindeki dist klasörünün içindeki bütün dosyaları kopyalıyoruz.
-> Projemizin içinde src/main/webapp içine bir swagger klasörü oluşturalım. Kopyaladığımız bütün dosyaları bu klasörün içine yapıştıralım.

3-) Şimdi de webconfig.java dosyamızın içine port bilgisi, url bilgisi, uygulama adı gibi swaggerı servera tanımlayacak bilgileri giriyoruz.

4-) Şimdi ise apimizi swagger uyumlu hale getirebilmek için kod içeriklerinde değişiklikler yapıyoruz.

Bu kısımda birçok ek açıklamalar kullanıyoruz.

@Api: Başına getirilen sınıfı bir swagger kaynağı olarak işaretler.

@ApiModel: Swagger modelleri hakkında bilgiler eklememizi sağlar.

@ApiOperation: Özel olarak belirlediğimiz bir yola karşılık gelen bir tanımlama yapar.

@ApiParam: İşlemdeki parametreleri tanımlarız.

@ApiResponse: İşlem sırasında oluşabilecek hataları tanımlarız.

Tüm bunları gerçekleştirdikten sonra şekildeki gibi bir görüntü çıkar.

Burada petstore uygulamasının Pet, Store ve User modellerinden User'ın içindeki işlemler yer almaktadır.

Bu uygulamanın kaynak kodu şu adreste bulunmaktadır.
 İyi çalışmalar dilerim.