Chuyển đến nội dung chính

Tùy Chọn Phương Thức

Tùy chọn phương thức là các tùy chọn có thể được thiết lập cho mỗi phương thức. Nếu tùy chọn có cùng khóa với một tùy chọn đã được thiết lập trong quá trình khởi tạo plugin, tùy chọn phương thức này sẽ ghi đè giá trị tùy chọn plugin.

Tùy Chọn Lưu

disableBlinkingCursor

  • Loại: boolean
  • Bắt buộc: Không
  • Mặc định: false
  • Hỗ trợ: Web, Ứng dụng Hybrid (Webview)

Bật/Tắt tất cả "nhấp nháy" con trỏ của input, textarea, [contenteditable] trong ứng dụng. Nếu được đặt thành true, con trỏ sẽ được đặt thành transparent trước khi chụp ảnh màn hình và đặt lại khi hoàn thành

disableCSSAnimation

  • Loại: boolean
  • Bắt buộc: Không
  • Mặc định: false
  • Hỗ trợ: Web, Ứng dụng Hybrid (Webview)

Bật/Tắt tất cả các hoạt ảnh CSS trong ứng dụng. Nếu được đặt thành true, tất cả các hoạt ảnh sẽ bị vô hiệu hóa trước khi chụp ảnh màn hình và đặt lại khi hoàn thành

enableLayoutTesting

  • Loại: boolean
  • Bắt buộc: Không
  • Mặc định: false
  • Sử dụng với: Tất cả phương thức
  • Hỗ trợ: Web

Điều này sẽ ẩn tất cả văn bản trên trang, vì vậy chỉ bố cục sẽ được sử dụng để so sánh. Việc ẩn sẽ được thực hiện bằng cách thêm style 'color': 'transparent !important' vào mỗi phần tử.

Đối với đầu ra, xem Test Output

thông tin

Khi sử dụng cờ này, mỗi phần tử chứa văn bản (không chỉ p, h1, h2, h3, h4, h5, h6, span, a, li, mà còn cả div|button|..) sẽ nhận thuộc tính này. Không có tùy chọn nào để điều chỉnh điều này.

hideScrollBars

  • Loại: boolean
  • Bắt buộc: Không
  • Mặc định: true
  • Sử dụng với: Tất cả phương thức
  • Hỗ trợ: Web, Ứng dụng Hybrid (Webview)

Ẩn thanh cuộn trong ứng dụng. Nếu được đặt thành true, tất cả thanh cuộn sẽ bị vô hiệu hóa trước khi chụp ảnh màn hình. Điều này được đặt mặc định là true để ngăn chặn các vấn đề phát sinh.

hideElements

  • Loại: array
  • Bắt buộc: không
  • Sử dụng với: Tất cả phương thức
  • Hỗ trợ: Web, Ứng dụng Hybrid (Webview), Ứng dụng Native

Phương thức này có thể ẩn 1 hoặc nhiều phần tử bằng cách thêm thuộc tính visibility: hidden vào chúng bằng cách cung cấp một mảng các phần tử.

removeElements

  • Loại: array
  • Bắt buộc: không
  • Sử dụng với: Tất cả phương thức
  • Hỗ trợ: Web, Ứng dụng Hybrid (Webview), Ứng dụng Native

Phương thức này có thể loại bỏ 1 hoặc nhiều phần tử bằng cách thêm thuộc tính display: none vào chúng bằng cách cung cấp một mảng các phần tử.

resizeDimensions

  • Loại: object
  • Bắt buộc: không
  • Mặc định: { top: 0, right: 0, bottom: 0, left: 0}
  • Sử dụng với: Chỉ dành cho saveElement hoặc checkElement
  • Hỗ trợ: Web, Ứng dụng Hybrid (Webview), Ứng dụng Native

Một đối tượng cần chứa số lượng pixel top, right, bottomleft cần thiết để làm cho vùng cắt của phần tử lớn hơn.

fullPageScrollTimeout

Thời gian chờ tính bằng mili giây sau khi cuộn. Điều này có thể giúp xác định các trang có tải chậm.

hideAfterFirstScroll

Phương thức này sẽ ẩn một hoặc nhiều phần tử bằng cách thêm thuộc tính visibility: hidden vào chúng bằng cách cung cấp một mảng các phần tử. Điều này sẽ hữu ích khi một trang ví dụ chứa các phần tử dính (sticky) sẽ cuộn theo trang nếu trang được cuộn nhưng sẽ tạo ra hiệu ứng khó chịu khi chụp ảnh toàn trang

waitForFontsLoaded

  • Loại: boolean
  • Bắt buộc: Không
  • Mặc định: true
  • Sử dụng với: Tất cả phương thức
  • Hỗ trợ: Web, Ứng dụng Hybrid (Webview)

Phông chữ, bao gồm cả phông chữ của bên thứ ba, có thể được tải đồng bộ hoặc bất đồng bộ. Việc tải bất đồng bộ có nghĩa là phông chữ có thể tải sau khi WebdriverIO xác định rằng trang đã tải hoàn toàn. Để tránh các vấn đề về hiển thị phông chữ, mô-đun này, theo mặc định, sẽ đợi tất cả các phông chữ được tải trước khi chụp ảnh màn hình.

Tùy Chọn So Sánh (Kiểm Tra)

Tùy chọn so sánh là các tùy chọn ảnh hưởng đến cách thức so sánh, được thực hiện bởi ResembleJS.

LƯU Ý
  • Tất cả các tùy chọn từ Tùy Chọn Lưu có thể được sử dụng cho các phương thức So sánh
  • Tất cả các tùy chọn so sánh có thể được sử dụng trong quá trình khởi tạo dịch vụ hoặc cho mỗi phương thức kiểm tra đơn lẻ. Nếu một tùy chọn phương thức có cùng khóa với một tùy chọn đã được thiết lập trong quá trình khởi tạo dịch vụ, thì tùy chọn so sánh phương thức sẽ ghi đè giá trị tùy chọn so sánh dịch vụ.
  • Tất cả các tùy chọn có thể được sử dụng cho:
    • Web
    • Ứng dụng Hybrid
    • Ứng dụng Native

ignoreAlpha

  • Loại: boolean
  • Mặc định: false
  • Bắt buộc: không

So sánh hình ảnh và bỏ qua alpha.

blockOutSideBar

  • Loại: boolean
  • Mặc định: true
  • Bắt buộc: không
  • Lưu ý: Chỉ có thể được sử dụng cho checkScreen(). Điều này chỉ dành cho iPad

Tự động chặn thanh bên cho iPad ở chế độ ngang trong khi so sánh. Điều này ngăn chặn các lỗi trên thành phần tab/private/bookmark gốc.

blockOutStatusBar

  • Loại: boolean
  • Mặc định: true
  • Bắt buộc: không
  • Lưu ý: Điều này chỉ dành cho Thiết bị di động

Tự động chặn thanh trạng thái và thanh địa chỉ trong quá trình so sánh. Điều này ngăn chặn các lỗi về thời gian, wifi hoặc trạng thái pin.

blockOutToolBar

  • Loại: boolean
  • Mặc định: true
  • Bắt buộc: không
  • Lưu ý: Điều này chỉ dành cho Thiết bị di động

Tự động chặn thanh công cụ.

ignoreAntialiasing

  • Loại: boolean
  • Mặc định: false
  • Bắt buộc: không

So sánh hình ảnh và bỏ qua khử răng cưa.

ignoreColors

  • Loại: boolean
  • Mặc định: false
  • Bắt buộc: không

Mặc dù hình ảnh có màu, việc so sánh sẽ so sánh 2 hình ảnh đen/trắng

ignoreLess

  • Loại: boolean
  • Mặc định: false
  • Bắt buộc: không

So sánh hình ảnh và so sánh với red = 16, green = 16, blue = 16, alpha = 16, minBrightness=16, maxBrightness=240

ignoreNothing

  • Loại: boolean
  • Mặc định: false
  • Bắt buộc: không

So sánh hình ảnh và so sánh với red = 0, green = 0, blue = 0, alpha = 0, minBrightness=0, maxBrightness=255

rawMisMatchPercentage

  • Loại: boolean
  • Mặc định: false
  • Bắt buộc: không

Nếu true, phần trăm trả về sẽ như 0.12345678, mặc định là 0.12

returnAllCompareData

  • Loại: boolean
  • Mặc định: false
  • Bắt buộc: không

Điều này sẽ trả về tất cả dữ liệu so sánh, không chỉ phần trăm không khớp

saveAboveTolerance

  • Loại: number
  • Mặc định: 0
  • Bắt buộc: không

Giá trị cho phép của misMatchPercentage ngăn việc lưu hình ảnh có sự khác biệt

largeImageThreshold

  • Loại: number
  • Mặc định: 0
  • Bắt buộc: không

So sánh hình ảnh lớn có thể dẫn đến vấn đề về hiệu suất. Khi cung cấp một số cho số lượng pixel ở đây (cao hơn 0), thuật toán so sánh sẽ bỏ qua các pixel khi chiều rộng hoặc chiều cao của hình ảnh lớn hơn largeImageThreshold pixel.

scaleImagesToSameSize

  • Loại: boolean
  • Mặc định: false
  • Bắt buộc: không

Tỷ lệ 2 hình ảnh về cùng một kích thước trước khi thực hiện so sánh. Rất khuyến khích bật ignoreAntialiasingignoreAlpha

Tùy chọn thư mục

Thư mục cơ sở và các thư mục ảnh chụp màn hình (thực tế, khác biệt) là các tùy chọn có thể được thiết lập trong quá trình khởi tạo plugin hoặc phương thức. Để đặt tùy chọn thư mục cho một phương thức cụ thể, hãy truyền tùy chọn thư mục vào đối tượng tùy chọn phương thức. Điều này có thể được sử dụng cho:

  • Web
  • Ứng dụng Hybrid
  • Ứng dụng Native
import path from 'node:path'

const methodOptions = {
actualFolder: path.join(process.cwd(), 'customActual'),
baselineFolder: path.join(process.cwd(), 'customBaseline'),
diffFolder: path.join(process.cwd(), 'customDiff'),
}

// Bạn có thể sử dụng điều này cho tất cả các phương thức
await expect(
await browser.checkFullPageScreen("checkFullPage", methodOptions)
).toEqual(0)

actualFolder

  • Loại: string
  • Bắt buộc: không

Thư mục cho ảnh chụp đã được chụp trong bài kiểm tra.

baselineFolder

  • Loại: string
  • Bắt buộc: không

Thư mục cho hình ảnh cơ sở được sử dụng để so sánh.

diffFolder

  • Loại: string
  • Bắt buộc: không

Thư mục cho sự khác biệt hình ảnh được hiển thị bởi ResembleJS.

Welcome! How can I help?

WebdriverIO AI Copilot