پرش به محتوای اصلی

زمان اجرای تست

به طور پیش‌فرض، این ماژول بررسی می‌کند که آیا نصب محلی Tesseract روی دستگاه/در خط لوله خود دارید. اگر نصب محلی ندارید، به طور خودکار از نسخه NodeJS استفاده می‌کند. این ممکن است باعث کندی شود زیرا پردازش تصویر توسط Node.js انجام می‌شود. NodeJS بهترین سیستم برای پردازش سنگین نیست.

اما... راه‌هایی برای بهینه‌سازی زمان اجرا وجود دارد. اسکریپت تست زیر را در نظر بگیرید

import { browser } from "@wdio/globals";

describe("Search", () => {
it("be able to search for a value", async () => {
await browser.url("https://webbrowser.io");
await browser.ocrClickOnText({
text: "Search",
});
await browser.ocrSetValue({
text: "docs",
value: "specfileretries",
});
await browser.ocrWaitForTextDisplayed({
text: "specFileRetries",
});
});
});

وقتی برای اولین بار این را اجرا می‌کنید، ممکن است نتایج زیر را مشاهده کنید که ۵.۹ ثانیه طول کشیده تا تست تمام شود.

npm run wdio -- --logLevel=silent

> ocr-demo@1.0.0 wdio
> wdio run ./wdio.conf.ts --logLevel=silent


Execution of 1 workers started at 2024-05-26T04:52:53.405Z

[0-0] RUNNING in chrome - file:///test/specs/test.e2e.ts
[0-0] Estimating resolution as 182
[0-0] Estimating resolution as 124
[0-0] Estimating resolution as 126
[0-0] PASSED in chrome - file:///test/specs/test.e2e.ts

"spec" Reporter:
------------------------------------------------------------------
[chrome 125.0.6422.78 mac #0-0] Running: chrome (v125.0.6422.78) on mac
[chrome 125.0.6422.78 mac #0-0] Session ID: d281dcdc43962b95835aea8f64cab6c7
[chrome 125.0.6422.78 mac #0-0]
[chrome 125.0.6422.78 mac #0-0] » /test/specs/test.e2e.ts
[chrome 125.0.6422.78 mac #0-0] Search
[chrome 125.0.6422.78 mac #0-0] ✓ be able to search for a value
[chrome 125.0.6422.78 mac #0-0]
[chrome 125.0.6422.78 mac #0-0] 1 passing (5.9s)


Spec Files: 1 passed, 1 total (100% completed) in 00:00:08

برش ناحیه جستجو در صفحه

می‌توانید با ارائه یک منطقه برش خورده برای اجرای OCR، زمان اجرا را بهینه کنید.

اگر اسکریپت را به این صورت تغییر دهید:

import { browser } from "@wdio/globals";

describe("Search", () => {
it("be able to search for a value", async () => {
await browser.url("https://webdriver.io");
await driver.ocrClickOnText({
haystack: $(".DocSearch"),
text: "Search",
});
await driver.ocrSetValue({
haystack: $(".DocSearch-Form"),
text: "docs",
value: "specfileretries",
});
await driver.ocrWaitForTextDisplayed({
haystack: $(".DocSearch-Dropdown"),
text: "specFileRetries",
});
});
});

سپس زمان اجرای متفاوتی را مشاهده خواهید کرد.

npm run wdio -- --logLevel=silent

> ocr-demo@1.0.0 wdio
> wdio run ./wdio.conf.ts --logLevel=silent


Execution of 1 workers started at 2024-05-26T04:56:55.326Z

[0-0] RUNNING in chrome - file:///test/specs/test.e2e.ts
[0-0] Estimating resolution as 182
[0-0] Estimating resolution as 124
[0-0] Estimating resolution as 124
[0-0] PASSED in chrome - file:///test/specs/test.e2e.ts

"spec" Reporter:
------------------------------------------------------------------
[chrome 125.0.6422.78 mac #0-0] Running: chrome (v125.0.6422.78) on mac
[chrome 125.0.6422.78 mac #0-0] Session ID: c6cb1843535bda3ee3af07920ce232b8
[chrome 125.0.6422.78 mac #0-0]
[chrome 125.0.6422.78 mac #0-0] » /test/specs/test.e2e.ts
[chrome 125.0.6422.78 mac #0-0] Search
[chrome 125.0.6422.78 mac #0-0] ✓ be able to search for a value
[chrome 125.0.6422.78 mac #0-0]
[chrome 125.0.6422.78 mac #0-0] 1 passing (4.8s)


Spec Files: 1 passed, 1 total (100% completed) in 00:00:08
برش تصاویر

این کار زمان اجرای محلی را از ۵.۹ به ۴.۸ ثانیه کاهش داد. این کاهش تقریباً ۱۹ درصد است. تصور کنید برای یک اسکریپت بزرگتر با داده‌های بیشتر چه تأثیری می‌تواند داشته باشد.

استفاده از نصب محلی Tesseract

می‌توانید زمان اجرا را به کمتر از یک دقیقه کاهش دهید اگر نصب محلی Tesseract روی سیستم محلی خود و یا در خط لوله خود داشته باشید (اطلاعات بیشتر در مورد نصب Tesseract روی سیستم محلی خود را می‌توانید اینجا پیدا کنید). زمان اجرای همان اسکریپت با استفاده از نصب محلی Tesseract را در زیر می‌توانید ببینید.

npm run wdio -- --logLevel=silent

> ocr-demo@1.0.0 wdio
> wdio run ./wdio.conf.ts --logLevel=silent


Execution of 1 workers started at 2024-05-26T04:59:11.620Z

[0-0] RUNNING in chrome - file:///test/specs/test.e2e.ts
[0-0] PASSED in chrome - file:///test/specs/test.e2e.ts

"spec" Reporter:
------------------------------------------------------------------
[chrome 125.0.6422.78 mac #0-0] Running: chrome (v125.0.6422.78) on mac
[chrome 125.0.6422.78 mac #0-0] Session ID: 87f8c1e949e15a383b902e4d59b1f738
[chrome 125.0.6422.78 mac #0-0]
[chrome 125.0.6422.78 mac #0-0] » /test/specs/test.e2e.ts
[chrome 125.0.6422.78 mac #0-0] Search
[chrome 125.0.6422.78 mac #0-0] ✓ be able to search for a value
[chrome 125.0.6422.78 mac #0-0]
[chrome 125.0.6422.78 mac #0-0] 1 passing (3.9s)


Spec Files: 1 passed, 1 total (100% completed) in 00:00:06
نصب محلی

این کار زمان اجرای محلی را از ۵.۹ به ۳.۹ ثانیه کاهش داد. این کاهش تقریباً ۳۴ درصد است. تصور کنید برای یک اسکریپت بزرگتر با داده‌های بیشتر چه تأثیری می‌تواند داشته باشد.

Welcome! How can I help?

WebdriverIO AI Copilot