Cẩm nang NQDEV
HomeCheat SheetsContact
Công nghệ
Công nghệ
  • Introduction
  • Developer Roadmaps
    • Developer Roadmaps: Mô tả chi tiết
    • Roadmaps: ASP.NET Core Developer
    • Bảng phân loại cấp độ nhà phát triển .NET
    • ClearPath cho Team .NET Core
  • DotNET
    • ASP.NET Core
      • Hướng dẫn sử dụng tệp .http trong Visual Studio 2022 để thực hiện HTTP Requests
    • Message Queue
      • ZeroMQ
        • Xây dựng ZeroMQ Server trong dotNET 8 với CSharp
    • Playwright
      • Playwright: Tự Động Hóa Trình Duyệt Hiệu Quả
    • Optimize
      • Optimize - Một số cách tối ưu code và performance CSharp
    • Dev Blogs
      • Versions of .NET
        • Cập nhật từ .NET 9 lên .NET 10: Những thay đổi quan trọng
      • ASP.NET Core Web API với ASP.NET Core Web API (Native AOT): Bạn nên chọn loại nào?
      • Hướng dẫn xây dựng ứng dụng multi-tenant với .NET Core và MongoDB
      • Kiến Trúc Monolithic và Microservices: Lựa Chọn Phù Hợp Cho Dự Án Của Bạn
  • Design Patterns
    • CQRS Pattern
      • CQRS and MediatR trong .NET Core
    • Microservices
      • Ocelot
  • SQL Server
    • SQL Server Basics
    • SQL Server: DBCC
      • DBCC
      • DBCC SHOW_STATISTICS
      • DBCC SHRINKDATABASE
      • DBCC SHRINKFILE
      • DBCC SQLPERF
      • DBCC FREEPROCCACHE
    • SQL Server Replication
      • Giới thiệu SQL Server Replication
      • Hướng dẫn cấu hình và quản lý SQL Server Replication với Distribution Agent
    • SQL Server: Tập lệnh
      • SQL Server: Tập lệnh để tìm tất cả các giá trị Mặc định với Cột
    • Bảng tạm và sự linh hoạt trong xử lý dữ liệu lớn
    • Các bước để thay đổi nơi lưu trữ tệp log trong SQL Server
    • Các bước di chuyển tệp log trong SQL Server
    • Query Store trong SQL Server - Tổng Quan và Cách Quản Lý Hiệu Quả
    • SQL Server: Error Code
      • SQL Server Error : 14151, Severity: 18. Replication agent
  • Caching
    • Phân tích các phương pháp Caching dữ liệu trong .NET Core và .NET Framework
    • Redis
      • Redis mất dữ liệu khi restart
    • Varnish Cache
      • Hướng Dẫn Cài Đặt Varnish Cache với HAProxy Sử Dụng Docker Compose
  • NodeJS
    • NextJS
      • Hướng dẫn NextJS cho người mới bắt đầu
      • Parallel Routes trong Next.js
      • Hướng dẫn cấu hình Swagger trong NextJS
    • ReactJS
      • Hiểu về hook useRef của React như thế nào cho đúng
      • Tìm hiểu sâu hơn về useEffect từ A-Z
  • OS Linux
    • Tập lệnh Linux hay dùng
    • Centos 7
      • Hướng dẫn cài đặt và cấu hình Centos 7 dành cho người mới bắt đầu
      • Hướng Dẫn Kiểm Tra Các Cổng Đang Mở Trên Hệ Thống CentOS
      • Hướng Dẫn Sử Dụng zip Trên CentOS
      • Hướng dẫn cấu hình iptables để mở tất cả các cổng cho IP private
    • Windows
      • Hướng dẫn quản lý ứng dụng khởi động Windows bằng Registry Editor
  • VMware
    • Cách ảo hóa macOS Sierra trong VMWare Windows 10
    • Tự tin làm chủ mạng lưới: Cẩm nang tính toán địa chỉ IP từ A đến Z
  • Docker
    • Getting Started with Docker
    • Docker HUB
      • nqdev/nginx
  • Templates
    • Tabler Admin Template: Xây dựng Dashboard Quản trị đẹp mắt và dễ dàng
  • Open Source
    • shadcn-ui/ui
    • Kuma UI
    • Midone
  • Ứng dụng
    • Ansible
      • Ansible: Giới thiệu
      • Hướng dẫn chi tiết cài đặt Ansible
    • Apache JMeter
      • Features
        • Hướng dẫn chi tiết về Test Plan trong JMeter
        • Hướng dẫn chi tiết về Thread Group trong JMeter
    • DocFX
      • Những khái niệm cơ bản trong DocFX
      • DocFX - Hướng dẫn cài đặt, cấu hình sử dụng
      • DocFX - Hướng dẫn Markdown
      • DocFX - Hướng dẫn cấu hình file docfx.json
      • DocFX - Hướng dẫn sử dụng và tùy chỉnh Template
    • ETL Tools
      • Công cụ ETL Tools List & Software
      • Airbyte
        • Docker Compose
    • Elasticsearch
      • _reindex
        • Tìm hiểu sâu về API _reindex trong Elasticsearch
        • Hướng dẫn di chuyển dữ liệu trong Elasticsearch sử dụng API _reindex
      • _transform
    • HAProxy
      • HAProxy - Lập trình Lua và tích hợp Redis
    • Localtunnel
      • Hướng dẫn sử dụng Localtunnel để đưa ứng dụng Local lên Internet
    • LoopBack
      • Hướng dẫn cài đặt LoopBack 4 và khởi tạo dự án đầu tiên
    • N8N
      • Hướng dẫn cài đặt n8n bằng docker compose
    • NGINX Plus
      • NGINX: Hiệu suất vượt trội và giải pháp tối ưu cho hệ thống web
      • NGINX: Hướng dẫn chi tiết sử dụng GeoIP2 trên Alpine
      • NGINX: Hướng dẫn sử dụng Lua trên Alpine
      • NGINX: Hướng Dẫn Chi Tiết Cấu Hình Load Balancer
      • NGINX: Hướng Dẫn Sử Dụng Dynamic Modules
      • NGINX: Hướng dẫn Cài đặt và Sử dụng Module njs
      • Tích Hợp NGINX Làm API Gateway với Các Bước Xử Lý Phổ Biến
    • NTP - Secure Timeserver
      • Hướng dẫn cài đặt NTP an toàn với Docker Compose
    • Playwright
      • Playwright: Tự Động Hóa Trình Duyệt Hiệu Quả
    • Wordpress
      • Cách dùng Docker để phát triển ứng dụng Wordpress
  • Tin tức
    • DevSecOps là gì?
    • Giới thiệu bộ công cụ hỗ trợ lập trình từ SmallDev.tools và Code Beautify
    • Giới Thiệu và Hướng Dẫn Về DuckDB
    • Giới thiệu về Các Loại Cơ Sở Dữ Liệu
      • 1. HSQLDB (HyperSQL Database)
    • Hệ thống phân giải tên miền (DNS) và các loại bản ghi
    • Giải thích về Tiền Tố Path Nổi Tiếng – /.well-known
    • Giải mã Hệ thống tạo mã OTP của Google Authenticator
    • Quishing là gì? Hiểu và phòng tránh lừa đảo qua mã QR
  • Hướng dẫn
    • Hướng dẫn chi tiết tạo tài khoản Google bằng email công ty
    • Top 10 ASP .NET Open Source Projects GitHub 2024
    • Free Themes and Templates from Creative Tim
    • Hướng dẫn sử dụng Voler và Mazer Dashboard từ Zuramai
  • So Sánh
    • So Sánh Apache Parquet và CSV: Bảng So Sánh Chi Tiết, Ưu và Nhược Điểm
    • So Sánh Varnish Cache, Memcached và Redis: Ba Công Cụ Caching Phổ Biến trong Tối Ưu Hóa Hiệu Suất
  • Affiliate
    • Tuyển dụng
      • Bộ câu hỏi phỏng vấn T-SQL – Đánh giá ứng viên hiệu quả
    • eSMSvn: Chăm sóc khách hàng hiệu quả với SMS và ZNS
    • eSMS.vn: Giải pháp SMS Marketing hiệu quả cùng các chương trình ưu đãi hấp dẫn
Powered by GitBook
On this page
  • 1. Playwright là gì?
  • 2. Cài đặt Playwright
  • Bước 1: Cài đặt Node.js
  • Bước 2: Cài đặt Playwright
  • Bước 3: Tải các trình duyệt
  • 3. Viết và chạy một kịch bản Playwright đơn giản
  • Tạo file kiểm thử
  • Chạy kiểm thử
  • 4. Một số tính năng nổi bật của Playwright
  • 4.1. Chụp ảnh màn hình
  • 4.2. Tự động hóa điền form
  • 4.3. Kiểm tra responsive
  • 4.4. Ghi lại kịch bản tự động
  • 5. Kết hợp Playwright với CI/CD
  • 6. Kết luận
  • Bạn muốn tìm hiểu thêm?

Was this helpful?

  1. Ứng dụng
  2. Playwright

Playwright: Tự Động Hóa Trình Duyệt Hiệu Quả

Chào mừng bạn đến với bài viết hướng dẫn Playwright - công cụ tự động hóa trình duyệt mạnh mẽ dành cho lập trình viên và tester!

Trong bài viết này, chúng ta sẽ tìm hiểu Playwright là gì, cách cài đặt và sử dụng Playwright để kiểm thử tự động hoặc tự động hóa các tác vụ trình duyệt.


1. Playwright là gì?

Playwright là một thư viện mã nguồn mở được phát triển bởi Microsoft, hỗ trợ tự động hóa trình duyệt web như Chromium, Firefox, và WebKit. Với Playwright, bạn có thể:

  • Kiểm thử giao diện người dùng trên nhiều trình duyệt và thiết bị.

  • Tự động hóa các tác vụ trình duyệt như điền form, chụp ảnh màn hình, và thu thập dữ liệu.

  • Mô phỏng hành vi người dùng, kiểm tra hiệu suất và khả năng tương thích của ứng dụng.


2. Cài đặt Playwright

Bước 1: Cài đặt Node.js

Trước tiên, hãy đảm bảo bạn đã cài đặt Node.js trên máy tính.

  • Kiểm tra Node.js bằng lệnh:

node -v
npm -v

Bước 2: Cài đặt Playwright

Chạy lệnh sau trong terminal:

npm install @playwright/test

Lệnh này sẽ cài đặt Playwright và các trình duyệt cần thiết.


Bước 3: Tải các trình duyệt

Sau khi cài đặt, tải các trình duyệt hỗ trợ:

npx playwright install

3. Viết và chạy một kịch bản Playwright đơn giản

Tạo file kiểm thử

Tạo file example.spec.js và thêm nội dung sau:

const { test, expect } = require('@playwright/test');

test('Kiểm tra tiêu đề của Google', async ({ page }) => {
    // Mở trang Google
    await page.goto('https://www.google.com');

    // Kiểm tra tiêu đề trang
    const title = await page.title();
    expect(title).toBe('Google');
});

Chạy kiểm thử

Chạy kiểm thử bằng lệnh:

npx playwright test

Kết quả sẽ hiển thị trạng thái bài kiểm thử (PASS hoặc FAIL).


4. Một số tính năng nổi bật của Playwright

4.1. Chụp ảnh màn hình

Thêm dòng sau vào file kiểm thử để chụp ảnh màn hình:

await page.screenshot({ path: 'screenshot.png' });

4.2. Tự động hóa điền form

Dưới đây là ví dụ điền form tìm kiếm Google:

await page.fill('input[name="q"]', 'Playwright');
await page.press('input[name="q"]', 'Enter');

4.3. Kiểm tra responsive

Mô phỏng thiết bị di động bằng cách cấu hình kích thước và user agent:

const iPhone11 = playwright.devices['iPhone 11'];
const browser = await playwright.chromium.launch();
const context = await browser.newContext({ ...iPhone11 });
const page = await context.newPage();
await page.goto('https://example.com');

4.4. Ghi lại kịch bản tự động

Playwright có công cụ ghi lại kịch bản:

npx playwright codegen

Công cụ này sẽ ghi lại các thao tác trên trình duyệt và tự động tạo mã kiểm thử.


5. Kết hợp Playwright với CI/CD

Playwright hỗ trợ tích hợp với các pipeline CI/CD phổ biến như GitHub Actions, Jenkins, hoặc GitLab CI. Bạn chỉ cần thêm Playwright vào workflow và thiết lập môi trường kiểm thử.

Ví dụ tích hợp với GitHub Actions:

name: Playwright Tests

on:
  push:
    branches:
      - main

jobs:
  test:
    runs-on: ubuntu-latest
    steps:
      - name: Checkout code
        uses: actions/checkout@v2

      - name: Setup Node.js
        uses: actions/setup-node@v2
        with:
          node-version: 16

      - name: Install dependencies
        run: npm install

      - name: Run Playwright tests
        run: npx playwright test

6. Kết luận

Playwright là một công cụ không thể thiếu cho các lập trình viên và tester hiện đại, giúp tự động hóa trình duyệt dễ dàng và hiệu quả. Với khả năng hỗ trợ đa trình duyệt, tích hợp CI/CD, và kiểm thử trên nhiều thiết bị, Playwright là giải pháp toàn diện cho kiểm thử ứng dụng web.

Hãy thử ngay và chia sẻ trải nghiệm của bạn trên blog Cẩm nang NQDEV!


Bạn muốn tìm hiểu thêm?

PreviousPlaywrightNextWordpress

Last updated 5 months ago

Was this helpful?

Nếu có câu hỏi hoặc muốn biết thêm về các tính năng khác của Playwright, hãy để lại bình luận bên dưới hoặc liên hệ với mình qua ! 😊

Cẩm nang NQDEV