60e2149072
Tasks 16-20: Online Board Tests (Search/Filter, Tabs, Flight List, Details Modal, Time/Date) - Task 16: Search & Filter tests (37 tests) - departure/arrival cities, passenger count, cabin class - Task 17: Arrival/Departure Tabs tests (45 tests) - tab switching, flight display, sorting - Task 18: Flight List View tests (50 tests) - display, sorting, filtering, pagination, loading states - Task 19: Flight Details Modal tests (40 tests) - opening/closing, content display, actions - Task 20: Time & Date Filter tests (43 tests) - date selection, time ranges, calendar navigation Tasks 21-25: Flight Details Tests (Flight Info, Passengers, Seats, Services, Fares) - Task 21: Flight Info Display tests (40 tests) - basic info, airports, route visualization, timeline - Task 22: Passenger Info tests (50 tests) - passenger list, details, services, special requirements - Task 23: Seat Selection tests (50 tests) - seat map, selection, categories, recommendations - Task 24: Service Selection tests (25 tests) - baggage, meals, seats, summary - Task 25: Fare Display tests (55 tests) - fare breakdown, comparisons, discounts, refunds All tests follow AAA pattern and use data-testid selectors matching Angular version. Total: 245 tests across 10 feature suites.
56 lines
2.0 KiB
Markdown
56 lines
2.0 KiB
Markdown
# Puppeteer
|
|
|
|
[](https://github.com/puppeteer/puppeteer/actions/workflows/ci.yml)
|
|
[](https://npmjs.org/package/puppeteer)
|
|
|
|
<img src="https://user-images.githubusercontent.com/10379601/29446482-04f7036a-841f-11e7-9872-91d1fc2ea683.png" height="200" align="right"/>
|
|
|
|
> Puppeteer is a Node.js library which provides a high-level API to control
|
|
> Chrome or Firefox over the
|
|
> [DevTools Protocol](https://chromedevtools.github.io/devtools-protocol/) or [WebDriver BiDi](https://pptr.dev/webdriver-bidi).
|
|
> Puppeteer runs in the headless (no visible UI) by default
|
|
> but can be configured to run in a visible ("headful") browser.
|
|
|
|
## [Get started](https://pptr.dev/docs) | [API](https://pptr.dev/api) | [FAQ](https://pptr.dev/faq) | [Contributing](https://pptr.dev/contributing) | [Troubleshooting](https://pptr.dev/troubleshooting)
|
|
|
|
## Installation
|
|
|
|
```bash npm2yarn
|
|
npm i puppeteer # Downloads compatible Chrome during installation.
|
|
npm i puppeteer-core # Alternatively, install as a library, without downloading Chrome.
|
|
```
|
|
|
|
## Example
|
|
|
|
```ts
|
|
import puppeteer from 'puppeteer';
|
|
// Or import puppeteer from 'puppeteer-core';
|
|
|
|
// Launch the browser and open a new blank page
|
|
const browser = await puppeteer.launch();
|
|
const page = await browser.newPage();
|
|
|
|
// Navigate the page to a URL.
|
|
await page.goto('https://developer.chrome.com/');
|
|
|
|
// Set screen size.
|
|
await page.setViewport({width: 1080, height: 1024});
|
|
|
|
// Type into search box.
|
|
await page.locator('.devsite-search-field').fill('automate beyond recorder');
|
|
|
|
// Wait and click on first result.
|
|
await page.locator('.devsite-result-item-link').click();
|
|
|
|
// Locate the full title with a unique string.
|
|
const textSelector = await page
|
|
.locator('text/Customize and automate')
|
|
.waitHandle();
|
|
const fullTitle = await textSelector?.evaluate(el => el.textContent);
|
|
|
|
// Print the full title.
|
|
console.log('The title of this blog post is "%s".', fullTitle);
|
|
|
|
await browser.close();
|
|
```
|