[Bài 1] Selenium Webdriver là gì?

[Bài 1] Selenium Webdriver là gì?


i. giới thiệu chung

selenium webdriver (se driver) là một tool open source giúp việc thực thi các hành động lên trang web một cách tự động, tất nhiên là tùy vào mục đích và yêu cầu của người viết. se driver hỗ trợ viết script trên nhiều ngôn ngữ khác nhau: java, c#, python, php… nhưng trong series này mình chỉ giới thiệu se driver qua ngôn ngữ java, vì mình chỉ biết java. 😀

về mặt bản chất, se driver là một 1 package trong đó có chứa rất nhiều các class, cung cấp các api hay gọi nôm na là thư viện. vì nó là thư viện nên cách sử dụng nó cũng chả khác gì việc sử dụng nhữngng thư viện khác mà java đã cung cấp sẵn như java.util hay java.lang.

Quý khách đang xem: [Bài 1] Selenium Webdriver là gì?

Xem nhiều hơn: Cool Boy Là Gì – Cách Trở Thành Cool Boy Với 5 Bước

ii. Để học được selenium webdriver thì cần những gì?

  • máy tính đã cài java 8 trở lên và có sẵn 1 bộ ide soạn thảo code (mình dùng intellij idea).
  • biết java cơ bản (nếu không biết thì học :v) mình có mở lớp java for tester cho những người chưa biết gì về lập trình.
  • cài sẵn các add-on như chropath / selector trên chrome để giúp lấy locator các element trên trang web.

iii. cách selenium webdriver làm việc?

1. test cript viết theo testcase

  • Để se driver có thể mô phỏng hành động như click chuột hay điền giá trị, đầu tiên nó phải xác định được vị trí của element (phần tử) trên trang web mà nó sẽ tương tác. (dựa vào css selector hoặc xpath)
  • sau khi đã xác định được vị trí, thì sẽ xác định hành động đối với element đó. (thông qua các api được viết sẵn trong các gói thư viện của webdriver, như đã nói ở trên)
  • sau khi hoàn thành 1 list các hành động theo trình tự ( giống như thực hiện với manual test), ta sẽ kiểm tra xem trang web có thực hiện đúng hay không

2. ví dụ: kiểm tra chức năng login

  • ta cần phải xác định được vị trí của các element: [username], [password] và [submit button] và nói cho webdriver biết vị trí của từng thằng.
  • hành động đối với [username] và [password] là nhập dữ liệu, ta sẽ dùng các phương thức nhập dữ liệu. với [submit button] thì ta dùng phương thức mô phỏng click chuột.
  • viết câu lệnh kiểm tra xem với dữ liệu nhập vào thì login có thành công hay không bằng cách xem nó có chuyển sang page khác hay vẫn ở lại page login … với thao tác bình thường, ta rất dễ có thể kiểm tra được xem login như thế là fail hay pass nhưng với automation, việc này sẽ được check tự động và phải chọn những điểm làm căn cứ để đánh dấu pass/fail.

3. khi run script, điều gì sẽ xảy ra?

khi viết xong script, mình muốn run để xem thử có bao nhiêu tc fail hay pass. khi run, se driver sẽ gọi trực tiếp (direct call)  trình duyệt thông qua driver của chính trình duyệt đó. sau đó các hành động trên script sẽ được thực thi.

chi tiết của direct call:

  1. với mỗi 1 hành động từ script, một http request sẽ được tạo ra
  2. http request đó gửi đến browser driver
  3. mỗi browser driver sẽ có 1 http server để nhận lấy http request
  4. sau khi nhận, http server xác định những bước cần thiết để thực thi hành động phản hồi lại request.
  5. http server thực thi những bước ở trên như mở trang web, điền thông tin vào thẻ input…
  6. sau đó, http server trả lại trạng thái thực hiện những hành động cho client, nơi đang run script.
[bài 1] selenium webdriver là gì?

iv. những trang web giúp học selenium webdriver nhanh hơn

–  www.seleniumhq.org

–  http://www.seleniumeasy.com

–  https://automationfc.com/category/selenium/selenium-webdriver/

–  https://www.guru99.com/selenium-tutorial.html

Xem nhiều hơn: Sửa lỗi window photo viewer can’t display this picture because there might not be enough memory trong 5 phút – Qnet88

v. tổng kết

Đây chỉ mới là bài giới thiệu về công cụ kiểm thử tự động mà nhà nhà nói, người người nói. sẽ còn rất nhiều điều phải học, phải làm nhưng mình tin là nó không quá khó, kể cả với những người còn kém lập trình như mình. 😀

Nguồn gốc: https://danhgiaaz.com
danh mục: Hỏi đáp

Trả lời

Email của bạn sẽ không được hiển thị công khai. Các trường bắt buộc được đánh dấu *