- vừa được xem lúc

[Playwright Interview question #8]: Page Object Model trong Playwright được implement như thế nào?

0 0 8

Người đăng: Playwright Việt Nam

Theo Viblo Asia

Câu hỏi phỏng vấn #8: Page Object Model trong Playwright được implement như thế nào?

Trả lời mẫu:

Page Object Model (POM) là design pattern phổ biến trong test automation:

1. Basic Page Object:

// pages/login.page.ts
export class LoginPage { constructor(page) { this.page = page; this.usernameInput = page.locator('#username'); this.passwordInput = page.locator('#password'); this.loginButton = page.locator('#login-btn'); } async login(username, password) { await this.usernameInput.fill(username); await this.passwordInput.fill(password); await this.loginButton.click(); }
}

2. Sử dụng trong test:

// tests/login.spec.js
import { LoginPage } from '../pages/LoginPage'; test('user can login', async ({ page }) => { const loginPage = new LoginPage(page); await page.goto('/login'); await loginPage.login('user@test.com', 'password123');
});

3. Advanced POM với getters:

export class ProductPage { constructor(page) { this.page = page; } get addToCartButton() { return this.page.locator('[data-test="add-to-cart"]'); } get productTitle() { return this.page.locator('.product-title'); }
}

💡 Tips:

  • Mỗi page = 1 class riêng
  • Store locators as properties hoặc getters
  • Methods represent user actions
  • Reuse page objects across multiple tests
  • Keep page objects focused và single responsibility

Lời Kết

Playwright đang trở thành một trong những automation frameworks phổ biến nhất cho web testing. Thông qua series này, hy vọng bạn sẽ:

  • Nắm vững kiến thức từ cơ bản đến nâng cao
  • Tự tin trong các buổi phỏng vấn
  • Áp dụng hiệu quả vào dự án thực tế
  • Trở thành một phần của cộng đồng Playwright Việt Nam năng động

📚 Bắt đầu hành trình của bạn với: Bài 1: Playwright vs Selenium

💬 Có câu hỏi? Tham gia group Facebook của chúng mình!

Theo dõi series để không bỏ lỡ bài viết mới!

Bình luận

Bài viết tương tự

- vừa được xem lúc

Page Object Pattern/Page Object Model trong automation test.

Page Object Pattern là gì. Page Object Pattern(POP) là 1 design pattern hỗ trợ trong mảng automation testing.

0 0 17

- vừa được xem lúc

Sử dụng Playwright để crawl dữ liệu - Phần 1

Nhân dịp đầu xuân, chúc anh chị em Viblo dồi dào sức khỏe, mã đáo thành công ạ ^^. Xin chào mọi người, hôm nay mình xin chia sẻ cách sử dụng Playwright - 1 framework cho testing mới ra lò cách đây.

0 0 47

- vừa được xem lúc

End-to-End Testing Renec Chain - Tương tác ví Demon - Playwright

In the fast-paced world of software development, ensuring the reliability and robustness of your blockchain-based applications is crucial. One way to achieve this is through end-to-end (E2E) testing.

0 0 38

- vừa được xem lúc

Automation test with Playwright

Chào các bạn. đây là tập các bài viết làm thế nào viết automaton test with playwright.

0 0 34

- vừa được xem lúc

Bài 2. Cài đặt Playwright

Hi, chào các bạn hôm nay mình sẽ hướng dẫn cài đặt playwright. tạo project automation test cho playwright nhé.

0 0 27

- vừa được xem lúc

Bài 3. First test case với Playwright

Hi chào các bạn. hôm nay mình sẽ tiếp viết phần tiếp theo của chuỗi bài cho viết automation test with playwright, bài hôm nay sẽ giới thiệu ngắn về test case đầu tiên.

0 0 30