Sơ lược về API testing

Tất cả chúng ta đang sống trong một thời đại trí tuệ tuyệt vời, nơi sự tiến bộ chuyển động với tốc độ chóng mặt. Tất cả chúng ta được kết nối với thế giới và tất cả mọi thứ. API (Application Programming Interface) là nhân vật không được nghe biết trong thế giới kết nối đó. Sau này là những điều bạn phải biết về API và kiểm thử API đóng một vai trò quan trọng thế nào.

Các API được sử dụng để tích hợp các mạng lưới hệ thống với nhau. Chúng ta có thể tạo sẵn tài liệu cho những mạng lưới hệ thống khác truy cập thông qua API hoặc chấp thuận tài liệu từ các mạng lưới hệ thống khác. Đây là cách các thiết bị và ứng dụng khác nhau nói chuyện với nhau và san sớt thông tin.

Các đơn vị thành công như Facebook, YouTube và Twitter sử dụng API để ứng dụng của họ có thể giao tiếp với những lớp học của bên thứ ba. Thông thường, API hoạt động tương tự như cách hoạt động của bất kỳ website nào. Yêu cầu (request) được gửi từ client tới server và kết quả phản hồi (response) thông qua giao thức http.

Ví dụ như người phục vụ trong một nhà hàng. Người phục vụ nhận yêu cầu – request (đơn đặt hàng) từ khách hàng (client) và chuyển nó đến nhà bếp (là server) và nhận thức ăn (phản hồi – response) từ bếp cho khách hàng. API thực hiện xác thực những điều đó. Một API là một sứ thần đưa ra yêu cầu của bạn và nói với những mạng lưới hệ thống những gì cần làm và sau đó trả về phản hồi cho bạn.

API testing là một loại kiểm thử phần mềm liên quan đến việc kiểm thử các giao diện lập trình ứng dụng (APIs) một cách trực tiếp và là một phần của kiểm thử tích hợp để xác định xem mạng lưới hệ thống có đáp ứng các yêu cầu về tính chất năng, độ tin cậy, hiệu suất và bảo mật thông tin. Vì các API không có GUI nên kiểm thử API được thực hiện tại tầng nghiệp vụ (bussiness layer) . Trong quá trình kiểm thử API, tài liệu được trao đổi từ XML hoặc JSON thông qua các yêu cầu và phản hồi HTTP ( HTTP requests and responses). Đây là những công nghệ độc lập và sẽ thao tác làm việc với nhiều tiếng nói lập trình và công nghệ khác nhau.

1. Kiểm thử ứng dụng sớm và không cần giao diện người dùng

Khi chúng ta tìm thấy lỗi càng muộn thì sẽ càng mất nhiều thời kì, sức lực lao động để fix nó. API testing đưa người kiểm thử tham gia sớm vào vòng đời phát triển sản phẩm. Với API testing, bạn cũng có thể khai mạc kiểm thử ứng dụng sớm ngay cả những lúc không có giao diện người dùng. Điều này giúp xác định và khắc phục sớm các vấn đề trong vòng đời phát triển, nếu không thì sẽ tốn kém để khắc phục khi được xác định trong quá trình kiểm thử GUI. Ưu điểm của việc kiểm thử API là rất nhiều logic có thể được kiểm tra mà không bị phụ thuộc vào UI.

2. Để đạt được một chiến lược kiểm thử tự động hóa tuyệt vời và giảm ngân sách.

Nếu tất cả chúng ta hiểu được “Kim tự tháp Tự động hóa hoá” ( Automation pyramid), tất cả chúng ta có thể đưa ra một chiến lược tự động hóa hóa hiệu quả.

Khái niệm kim tự tháp được Mike Cohn phát triển và được mô tả trong cuốn sách “Thành công với Agile”. Tầng thứ nhất của kim tự tháp là Unit test. Thực hiện unit test là cách nhanh nhất và mang lại kết quả rất tốt. Tầng thứ hai là kiểm thử API dựa trên service layer. Cuối cùng, ở đỉnh của kim tự tháp là kiểm thử UI.

Đi từ tầng dưới kim tự tháp lên trên, ngân sách liên quan đến việc tạo ra và duy trì các phương pháp kiểm thử, thời kì thực hiện kiểm thử, phạm vi kiểm thử sẽ tăng lên. Các kim tự tháp tự động hóa (Automation pyramid) nói rằng bạn nên làm nhiều hơn nữa kiểm thử tự động hóa thông qua Unit test và API hơn là kiểm thử dựa trên GUI. Sự thành công của Agile rất phụ thuộc vào phản hồi (feedback) sớm. Trong các thực tiễn, việc tích hợp liên tục, thời kì kiểm thử hồi quy GUI và nhận lại phản hồi quá dài. Kiểm tra giao diện người dùng rất tốn kém để phát triển và duy trì. Một sự thay đổi nhỏ trong giao diện người dùng cũng sẽ có thể dẫn đến việc thực hiện kiểm thử lại rất nhiều.

Trong một số trường hợp, người kiểm thử sẽ phải thực hiện tự động hóa hoá tại tầng UI. Tuy nhiên, kiểm thử có thể chậm và tốn nhiều chih phí. Đây là một trong những lý do khiến nhiều đơn vị thất bại trong nỗ lực thực hiện chiến lược tự động hóa hoá hiệu quả.

3. Phát triển phần mềm theo phương pháp Agile và giảm việc thực hiện kiểm thử hồi quy bằng tay

Theo một cuộc khảo sát gần đây của VersionOne, 95% người được hỏi cho biết thêm tổ chức của họ sử dụng phương pháp Agile. Agile không chỉ sử dụng ở những đơn vị startup và những nhóm phát triển sản phẩm nhỏ. Lý do chính để vận dụng Agile thay vì phương pháp truyền thống là đẩy nhanh việc phân phối sản phẩm và chấp thuận những thay đổi. Agile đã và đang tăng tần số mà các ứng dụng được phát hành, do này đã tạo ra nhu cầu ngày càng tăng về những phương pháp mới để sớm kiểm tra chúng. Kiểm tra tự động hóa hóa đã trở thành một yếu tố quan trọng để duy trì tính nhanh chóng. Vì vậy, cấp thiết cho những đội Agile tăng mức độ kiểm thử API và giảm sự phụ thuộc của họ vào việc kiểm tra GUI.

Tự động hóa hóa API có thể giảm đáng kể sức ép của kiểm thử hồi quy của nhóm QA. Bằng phương pháp tích hợp kiểm thử tự động hóa API , nhóm QA có thể cung cấp phản hồi nhanh về chất lượng sản phẩm ứng dụng ngay trong khi được triển khai (deploy). Điều này cung cấp một nhìn nhận và đánh giá nhanh chóng về mạng lưới hệ thống trước lúc kiểm thử GUI. Kiểm thử tự động hóa API yêu cầu code thấp hơn và cung cấp kết quả kiểm tra nhanh hơn và phạm vi kiểm tra tốt hơn. API được ổn định sớm và không thay đổi thường xuyên như giao diện người dùng.

API testing là một hình thức thử nghiệm phần mềm độc đáo và đặc biệt quan trọng có mức giá trị so với các doanh nghiệp nắm bắt quá trình hội nhập liên tục. Việc xây dựng trường hợp kiểm thử API trong quá trình phát triển bất kỳ phần mềm hoặc dịch vụ nào có những lợi ích sâu rộng trong các đội, tất cả đều là cách khách hàng trải nghiệm sản phẩm. Làm phần mềm mà khách hàng tiềm năng của các bạn sẽ yêu thích là điều thiết yếu cho việc thành công của doanh nghiệp và bằng phương pháp kiểm thử API một cách nghiêm túc và thường xuyên, là một cách đáng tin cậy để đạt được nó.

Postman là một ứng dụng Google Chrome giúp cho bạn tạo, lưu, gửi yêu cầu HTTP (HTTP request) và kiểm tra tài liệu phản hồi ( request) . Nó giúp tự động hóa hoá quá trình tạo ra các yêu cầu API và kiểm tra các phản hồi API, được chấp nhận thiết lập một quy trình thao tác làm việc rất hiệu quả. Hồ hết các lập trình viên và người kiểm thử đều thân thuộc với Postman. Tuy nhiên, nhiều người sử dụng nó chỉ để kiểm tra phản hồi cho những dịch vụ mà người ta đang thao tác làm việc trên. Họ không biết về các tính năng mạnh mẽ mà Postman đưa ra như: Collections, Tests and Pre-request scripts. Nội dung bài viết này sẽ ra một chiếc nhìn tổng quát của Postman .

Lý do chính tôi thích Postman là vì khả năng tự động hóa hóa mạnh mẽ của nó. Hơn nữa, việc học tập để sử dụng nó là rất dễ dàng và ứng dụng cung cấp một giao diện người dùng rất trực quan để kiểm tra yêu cầu sever của bạn.Nó sẽ xác nhận hợp thức mỗi lần nếu đáp ứng đúng. Viết test trên Postman được thực hiện dễ dàng bằng các đoạn mã JavaScript, được chấp nhận cả những tester thiếu kinh nghiệm kiểm thử một cách hiệu quả.

Postman là mạng lưới hệ thống thời kì thực giúp lập trình viên và QA kiểm thử API dễ dàng hơn. Postman giúp làm giảm sức ép khi thực hiện kiểm thử hồi quy của nhóm QA. Việc tự động hóa hoá kiểm thử API giúp tiết kiệm ngân sách và chi phí thời kì hơn là tự động hóa hoá kiểm thử UI. Ưu điểm chính của tự động hóa hóa API là tất cả chúng ta có thể truy cập vào ứng dụng mà không có giao diện người dùng. Điều này cung cấp một nhìn nhận và đánh giá thuở đầu về tổng thể sức mạnh mạng lưới hệ thống trước lúc bắt tay vào kiểm thử GUI.

Bằng phương pháp tích hợp tự động hóa hoá kiểm thử API, nhóm QA có thể cung cấp phản hồi nhanh về chất lượng sản phẩm của ứng dụng ngay trong khi được triển khai.

Nội dung bài viết được dịch lại từ nguồn: http://www.logigear.com/magazine/api-testing/everything-you-need-to-know-about-api-testing/

You May Also Like

About the Author: v1000