Ana içeriğe atla

Cypress Notlar-1

 Notlar

npm (node package manager), javascript betik dili için geliştirilmiş olan ve Node.js'in standart olarak kabul ettiği bir paket yönetim sistemidir. npm komut satırından çalıştırılır ve uygulamalar için bağımlılık yönetimi sağlar.
 
npm'yi yükleyip cypress'i yüklemeyi tavsiye ediyorlar. Cypress'i yazdığınız kodun içine yükleyin.
npm install -D cypress
 
Yüklendikten sonra cypress
npx cypress open, cypress in test runner ını açıyor. 
 
Cypress için hangi IDE'yi kullandığınız önemli değil ama genelde Visual Studio Code kullanılıyor.
 
Cypress la test yaparken güvenlikle alakalı hata alırsan cypress.json dosyasına aşağıdaki yazılır.
{ "chromeWebSecurity" = false } 
 
Buraya hep aynı url ye gideceksen baseURL olarak tanımlama yapabilirsin. Açılacak tarayıcının boyutunu buradan ayarlayabilirsin. 
 
Fixtures klasörüne kodunda kullanacağın sabit veriyi yazabilirsin. Yeni bir json dosyası oluşturup aşağıdaki gibi ekleyebilirsin. (swaglabs.json)
 
{
"name": "Sinem",
"password": "Password",
}
 
Bu veriyi aşağıdaki login fonksiyonunda çağırıp kullanabilirsin. (swaglabs.cy.js)
 
///<reference types="Cypress"> />
describe ('Ilk Test', () => {
it('Login with Method', () =>{
cy.fixture("swaglabs").as("user")
cy.visit('https://www.saucedemo.com')
cy.get("@user").then((user) => {
cy.login(user.username, user.password)
})

})
})
 
Login fonksiyonunu "support" klasörünün altındaki "commands.js" dosyasına eklemen lazım önce. Commands dosyası sürekli kullandığın fonksiyonları yazabileceğin bir dosyadır. Test dosyanda değişkeni gönderip bu fonksiyonu çağırabilirsin ya da Fixtures klasöründeki json dosyandan çağırabilirsin.
Cypress.Commands.add('login', (email, password) => {
cy.visit('/login')
.get('#email_input').type(email)
.get('#password_input').type(password)
.get('button.submit').click()
});
 
POM(Page Object Model), kod tekrarını önlemek için oluşturulan tasarım kalıbıdır. Objeleri, metodları test kodundan uzak tutar ve tekrar kullanımını sağlar.
Page objects için ana klasörünün altında bir js dosyası oluşturup örneğin Login fonksiyonları orada tanımlayıp test dosyanda import ile çağırabilirsin. 
Mesela Page Objects diye Cypress klasörünün altında bir klasör oluşturup json dosyasına böyle fonksiyonlarını yazabilirsin.
 
export class LoginwithPOM{

enterUsername(){
cy.get("[id = 'login2']", {timeout:3000}).click() //Wait for the form to open
cy.get("[id='loginusername']").type("Sinem", {timeout:3000}).should("be.visible")
}
enterPassword(){
cy.get("#loginpassword").type('123456');
}
clickLogin(){
cy.get('[onclick="logIn()"]').click();
}

clickLogout(){
cy.get('#logout2').click();
}

}
  
Bu kendi test dosyan. POM için oluşturduğun dosya neredeyse en başta onun yerini belirtmen lazım. Sonra constructor oluşturuyorsun. Ve onun fonksiyonlarını çağırıyorsun.
import {LoginwithPOM} from "../pageobjects/login";
const Pom = new LoginwithPOM();

describe ('Demo Blaze Login POM Test', () => {

it('Go to Website', () => {
cy.visit('https://demoblaze.com')
Pom.enterUsername()
Pom.enterPassword()
Pom.clickLogin()
cy.contains("Welcome Sinem").should("be.visible")
Pom.clickLogout()
})
})
Cypress.json dosyasına kendi Timeout değerini de yazabilirsin.  
 
Cypress Dashboard, testlerini koştururken tek bir yerden takip edebileceğin bir alan. Hatalarının resimleri vs de var. Ne kadar süreceği, kaçı geçti, kaldı vs gibi bilgiler de edinebilirsin. Project settings'teki "Record Keys" teki key'i alıp projenin terminalinde aşağıdaki kodu yazmalısın.
npx cypress run --record --key recordkeystenaldığınkod
 
Cypress tarayıcının ekran görüntüsünü istediğin formatta ayarlamana izin verir. İstersen bir mobil telefon görüntüsü de (iphone, ipad, macbook, samsungun bazıları var) ayarlayabilirsin. Her test için ayrı olsun istersen it() den sonra yazman gerekir ama bütün hepsi için olsun istersen beforeEach() fonksiyonunda aşağıdaki gibi belirtmen gerekir.
cy.viewport("ipad-mini")

beforeEach(() =>{
cy.viewport("samsung-note9")
})

Yorumlar

Bu blogdaki popüler yayınlar

Selenium - XPath Kodları

XPath, XML Path Absolute XPath: root node u verir ve / ile başlar Elementin path inde herhangi bir değişiklik yapılırsa, test kodu hata verir. Örn:  html/body/div[1]/section/div[1]/div/div/div/div[1]/div/div/div/div/div[3]/div[1]/div/h4[1]/b Relative XPath: xml dokümanındaki elementi verir ve // ile başlar Örn : //*[@class='featured-box']//*[text()='Testing'] XPath Kombinasyonları: Belli bir tagin belli bir attribute değeri ile kullanımı Herhangi bir tag in belli bir attribute değeri ile kullanımı "and" operatörü "or" operatörü Belirli bir değer ile başlayan attribute Metnin bir kısmını içeren attribute Sadece text() Herhangi bir attribute un değeri Belli Bir Tag'ın Belli Bir Attribute Değeri ile Kullanımı (Specific tag with specific attribute value) Html Kodu < input   id = "Lid"  .....   > input:tag adı (etiket adı) id : attribute Lid : attribute değeri Selenium Kodu driver.findElement(By.x...

Otomasyon Testlerini JUnit ile Önceliklendirme

Kullandığınız IDE'de ilk olarak çalışmasını istediğiniz kodun @Test annotation'ının üstüne  @Category({Critical.class}) yazın. İkinci olarak çalışmasını istediğinizin üzerine; @Category({Major.class}) yazın. Bu categoriler için Critical ve Major interfacelerini oluşturun. Critical interface inin içine import org.junit.experimental.categories.Categories; import org.junit.runner.RunWith; @RunWith(Categories.class) @Categories.IncludeCategory({Critical.class}) public interface Critical { } Major categorisinin içine import org.junit.experimental.categories.Categories; import org.junit.runner.RunWith; @RunWith(Categories.class) @Categories.IncludeCategory({Major.class}) public interface Major { } yazın. pom.xml'e <profiles>             <profile>                 <id> All </id>                 <build> ...