# Instructions - Following Playwright test failed. - Explain why, be concise, respect Playwright best practices. - Provide a snippet of code with the fix, if possible. # Test info - Name: src/manager/tests/e2e/insurance/insurance-edit-booking-portal.spec.ts >> edits the short description - Location: src/manager/tests/e2e/insurance/insurance-edit-booking-portal.spec.ts:8:7 # Error details ``` Test timeout of 75000ms exceeded. ``` ``` Error: locator.click: Test timeout of 75000ms exceeded. Call log: - waiting for locator('.v-dialog:has([data-test-id="insurance-edit-booking-portal-dialog"]):has(.v-overlay__content:not(.dialog-bottom-transition-enter-active))').getByTestId('language-aware-input').getByRole('button', { name: 'English', exact: true }) ``` # Page snapshot ```yaml - generic [ref=e1]: - generic [ref=e6]: - navigation [ref=e7]: - generic [ref=e9]: - link [ref=e10] [cursor=pointer]: - /url: / - button [ref=e11] [cursor=pointer]: - img [ref=e12] - list [ref=e15]: - generic [ref=e17]: Dashboard - link "Tasks" [ref=e18] [cursor=pointer]: - /url: /tasks - img [ref=e21] - generic [ref=e24]: Tasks - link "Facility maps" [ref=e25] [cursor=pointer]: - /url: /facility-map - generic [ref=e27]: 󰧾 - generic [ref=e29]: Facility maps - link "Analytics" [ref=e30] [cursor=pointer]: - /url: /dashboard - generic [ref=e32]: 󱖶 - generic [ref=e34]: Analytics - generic [ref=e36]: Sales - link "Bookings" [ref=e37] [cursor=pointer]: - /url: /bookings - generic [ref=e39]: 󰇡 - generic [ref=e41]: Bookings - link "Customers" [ref=e42] [cursor=pointer]: - /url: /customers - generic [ref=e44]: 󰀏 - generic [ref=e46]: Customers - link "Invoices" [ref=e47] [cursor=pointer]: - /url: /invoices - generic [ref=e49]: 󰷉 - generic [ref=e51]: Invoices - link "Credit notes" [ref=e52] [cursor=pointer]: - /url: /credit-notes - img [ref=e55] - generic [ref=e58]: Credit notes - link "Units" [ref=e59] [cursor=pointer]: - /url: /units - generic [ref=e61]: 󰍀 - generic [ref=e63]: Units - generic [ref=e65]: Site management - link "Locations" [ref=e66] [cursor=pointer]: - /url: /locations - generic [ref=e68]: 󰟙 - generic [ref=e70]: Locations - link "Unit types" [ref=e71] [cursor=pointer]: - /url: /unit-types - generic [ref=e73]: 󰆧 - generic [ref=e75]: Unit types - link "Protection Plans" [ref=e76] [cursor=pointer]: - /url: /insurances - generic [ref=e78]: 󰳌 - generic [ref=e80]: Protection Plans - link "Deposits" [ref=e81] [cursor=pointer]: - /url: /deposits - generic [ref=e83]: 󱙆 - generic [ref=e85]: Deposits - link "Products" [ref=e86] [cursor=pointer]: - /url: /products - generic [ref=e88]: 󰄑 - generic [ref=e90]: Products - link "Discounts" [ref=e91] [cursor=pointer]: - /url: /discounts - generic [ref=e93]: 󰓼 - generic [ref=e95]: Discounts - generic [ref=e96]: - option "Emails" [ref=e97] [cursor=pointer]: - generic [ref=e99]: 󰻨 - generic [ref=e101]: Emails - generic [ref=e105]: 󰅀 - text: 󱡰 󰁥 - generic [ref=e107]: Admin - link "Integrations" [ref=e108] [cursor=pointer]: - /url: /connected-apps - generic [ref=e110]: 󱘖 - generic [ref=e112]: Integrations - link "User & Roles" [ref=e113] [cursor=pointer]: - /url: /users - generic [ref=e115]: 󰭘 - generic [ref=e117]: User & Roles - generic [ref=e118]: - option "Booking Portal" [ref=e119] [cursor=pointer]: - generic [ref=e121]: 󱃁 - generic [ref=e123]: Booking Portal - generic [ref=e127]: 󰅀 - text: 󰖟 󰟙 - generic [ref=e128]: - option "JaneAI" [ref=e129] [cursor=pointer]: - generic [ref=e131]: 󱙺 - generic [ref=e133]: JaneAI - generic [ref=e137]: 󰅀 - text: 󱜹 - generic [ref=e139]: Feedback - link "Voting Portal" [ref=e140] [cursor=pointer]: - /url: /voting-portal - generic [ref=e142]: 󰔔 - generic [ref=e144]: Voting Portal - generic [ref=e146]: - button "AS Andreas Stadler andreas.stadler@storeroom.at" [ref=e149] [cursor=pointer]: - generic [ref=e152]: AS - generic [ref=e153]: - generic [ref=e154]: Andreas Stadler - generic "andreas.stadler@storeroom.at" [ref=e155] - generic [ref=e156]: 󰇙 - generic: - text: 󰗊 󰅀 - text: 󰷖 󰍃 - button [ref=e157] [cursor=pointer]: - generic [ref=e159]: 󰋽 - main [ref=e160]: - generic [ref=e162]: - generic [ref=e164]: - generic [ref=e165]: - link "Protection Plan" [ref=e166] [cursor=pointer]: - /url: /insurances - generic [ref=e167]: 󰁍 - generic [ref=e168]: Protection Plan - generic [ref=e169]: 󰅂 - generic [ref=e170]: Ergonomic Insurance aQAK7a - button "Actions" [ref=e172] [cursor=pointer]: - generic [ref=e173]: - text: Actions - generic [ref=e174]: 󱨉 - generic [ref=e176]: - generic [ref=e177]: - generic [ref=e179]: - generic [ref=e181]: - heading "General" [level=3] [ref=e183] - link [ref=e185] [cursor=pointer]: - /url: /insurances/1640063714/edit/general - generic [ref=e187]: 󰲶 - table [ref=e190]: - rowgroup [ref=e191]: - row "Name Ergonomic Insurance aQAK7a" [ref=e192]: - rowheader "Name" [ref=e193] - cell "Ergonomic Insurance aQAK7a" [ref=e194]: - generic "Ergonomic Insurance aQAK7a" [ref=e196] - row "Location Vienna South" [ref=e197]: - rowheader "Location" [ref=e198] - cell "Vienna South" [ref=e199]: - generic "Vienna South" [ref=e201] - generic [ref=e202]: - generic [ref=e203]: - generic [ref=e205]: - heading "Booking portal" [level=3] [ref=e207] - link [ref=e209] [cursor=pointer]: - /url: /insurances/1640063714/edit/storefront - generic [ref=e211]: 󰲶 - table [ref=e214]: - rowgroup [ref=e215]: - row "Short description -" [ref=e216]: - rowheader "Short description" [ref=e217] - cell "-" [ref=e218]: - generic [ref=e220]: "-" - generic [ref=e221]: - generic [ref=e223]: - heading "Taxes" [level=3] [ref=e225] - link [ref=e227] [cursor=pointer]: - /url: /insurances/1640063714/edit/tax - generic [ref=e229]: 󰲶 - table [ref=e232]: - rowgroup [ref=e233]: - row "B2C 20%" [ref=e234]: - rowheader "B2C" [ref=e235] - cell "20%" [ref=e236]: - generic "20%" [ref=e238] - row "B2B 20%" [ref=e239]: - rowheader "B2B" [ref=e240] - cell "20%" [ref=e241]: - generic "20%" [ref=e243] - generic [ref=e245]: - generic [ref=e247]: - heading "Booking plan" [level=3] [ref=e249] - link [ref=e251] [cursor=pointer]: - /url: /insurances/1640063714/booking-plan - generic [ref=e253]: 󰐙 - generic [ref=e256]: - generic [ref=e258]: - generic [ref=e261]: - button "Edit price" [disabled] [ref=e265]: - img [ref=e267] - generic [ref=e273]: Edit price - button "Publish" [disabled] [ref=e276]: - generic [ref=e278]: 󰛐 - generic [ref=e279]: Publish - button "Unpublish" [disabled] [ref=e282]: - generic [ref=e284]: 󰛑 - generic [ref=e285]: Unpublish - button "Delete" [disabled] [ref=e289]: - generic [ref=e291]: 󰩺 - generic [ref=e292]: Delete - table [ref=e294]: - rowgroup [ref=e295]: - row "Billing period Discount Price / period (excl. VAT) Period price (excl. VAT) Status Active Bookings Action" [ref=e296]: - columnheader [ref=e297]: - generic [ref=e298]: - checkbox [ref=e299] - generic [ref=e301] [cursor=pointer]: 󰄱 - columnheader "Billing period" [ref=e302]: - button "Billing period" [ref=e303] [cursor=pointer]: - generic [ref=e305]: Billing period - generic [ref=e308]: 󰁝 - columnheader "Discount" [ref=e309]: - button "Discount" [ref=e310] [cursor=pointer]: - generic [ref=e312]: Discount - generic [ref=e315]: 󰁝 - columnheader "Price / period (excl. VAT)" [ref=e316]: - button "Price / period (excl. VAT)" [ref=e317] [cursor=pointer]: - generic [ref=e319]: Price / period (excl. VAT) - generic [ref=e322]: 󰁝 - columnheader "Period price (excl. VAT)" [ref=e323]: - button "Period price (excl. VAT)" [ref=e324] [cursor=pointer]: - generic [ref=e326]: Period price (excl. VAT) - generic [ref=e329]: 󰁝 - columnheader "Status" [ref=e330]: - generic [ref=e333]: Status - columnheader "Active Bookings" [ref=e334]: - button "Active Bookings" [ref=e335] [cursor=pointer]: - generic [ref=e337]: Active Bookings - generic [ref=e340]: 󰁝 - columnheader "Action" [ref=e341]: - generic [ref=e344]: Action - row [ref=e345]: - columnheader [ref=e346] - rowgroup [ref=e347]: - row "1 month 0% €150.00 €150.00 Published 0" [ref=e348]: - cell [ref=e349]: - generic [ref=e350]: - checkbox [ref=e351] - generic [ref=e353] [cursor=pointer]: 󰄱 - cell "1 month" [ref=e354]: - generic [ref=e355]: 1 month - cell "0%" [ref=e356]: - generic [ref=e357]: 0% - cell "€150.00" [ref=e358]: - generic [ref=e359]: €150.00 - cell "€150.00" [ref=e360]: - generic [ref=e361]: €150.00 - cell "Published" [ref=e362]: - generic [ref=e366]: Published - cell "0" [ref=e367]: - generic [ref=e368]: "0" - cell [ref=e369]: - button [ref=e372] [cursor=pointer]: - generic [ref=e374]: 󰇘 - generic: 󰲶 󰩺 - generic [ref=e377]: - generic [ref=e378]: - generic [ref=e379]: "Items per page:" - combobox [ref=e382]: - generic [ref=e384] [cursor=pointer]: - generic [ref=e386]: "5" - combobox "Items per page:": "5" - generic [ref=e388]: 󰍝 - generic [ref=e389]: 1-1 of 1 - generic [ref=e390]: - button [disabled]: - generic: - generic: 󰘀 - button [disabled]: - generic: - generic: 󰅁 - button [disabled]: - generic: - generic: 󰅂 - button [disabled]: - generic: - generic: 󰘁 - generic: - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - dialog: - generic [ref=e393]: - heading "Booking portal" [level=3] [ref=e397] - generic [ref=e407]: - generic [ref=e408]: - tablist [ref=e409]: - generic: - generic: 󰅁 - generic [ref=e411]: - tab "English" [selected] [ref=e412] [cursor=pointer]: - generic [ref=e413]: English - tab "Swedish" [ref=e414] [cursor=pointer]: - generic [ref=e415]: Swedish - tab "Slovenian" [ref=e416] [cursor=pointer]: - generic [ref=e417]: Slovenian - tab "Russian" [ref=e418] [cursor=pointer]: - generic [ref=e419]: Russian - tab "Portugese" [ref=e420] [cursor=pointer]: - generic [ref=e421]: Portugese - tab "Polish" [ref=e422] [cursor=pointer]: - generic [ref=e423]: Polish - tab "Norwegian" [ref=e424] [cursor=pointer]: - generic [ref=e425]: Norwegian - tab "Dutch" [ref=e426] [cursor=pointer]: - generic [ref=e427]: Dutch - tab "Latvian" [ref=e428] [cursor=pointer]: - generic [ref=e429]: Latvian - tab "French" [ref=e430] [cursor=pointer]: - generic [ref=e431]: French - tab "Finnish" [ref=e432] [cursor=pointer]: - generic [ref=e433]: Finnish - tab "Spanish" [ref=e434] [cursor=pointer]: - generic [ref=e435]: Spanish - tab "Greek" [ref=e436] [cursor=pointer]: - generic [ref=e437]: Greek - tab "German" [ref=e438] [cursor=pointer]: - generic [ref=e439]: German - tab "Czech" [ref=e440] [cursor=pointer]: - generic [ref=e441]: Czech - tab "Catalan" [ref=e442] [cursor=pointer]: - generic [ref=e443]: Catalan - generic [ref=e445] [cursor=pointer]: 󰅂 - separator [ref=e446] - generic [ref=e448]: - generic [ref=e451]: - generic: Short description - textbox "Short description" [ref=e452] - alert [ref=e453] - contentinfo [ref=e456]: - generic [ref=e459]: - button "Cancel" [ref=e460] [cursor=pointer]: - generic [ref=e461]: Cancel - button "Save" [ref=e462] [cursor=pointer]: - generic [ref=e463]: Save ``` # Test source ```ts 1 | import { TextAreaField } from '@/manager/shared/components/TextAreaField'; 2 | import { languages } from '@/shared/data/seed-languages'; 3 | import { BaseComponent } from '@/shared/base/BaseComponent'; 4 | import { getInputHostByLabel } from '@/manager/shared/utils/locator-utils'; 5 | import { LanguageKey, LanguageRecordPartial } from '@/shared/types/language-types'; 6 | import { Locator } from '@playwright/test'; 7 | 8 | export class LanguageAwareInput extends BaseComponent { 9 | private readonly main = this.host.getByTestId('language-aware-input'); 10 | private readonly textAreaField = new TextAreaField(getInputHostByLabel(this.main, 'Short description')); 11 | 12 | async fill(values: LanguageRecordPartial): Promise { 13 | for (const [key, value] of Object.entries(values) as [LanguageKey, string | undefined][]) { 14 | if (value === undefined) { 15 | continue; 16 | } 17 | > 18 | await this.getLanguageButton(key).click(); | ^ Error: locator.click: Test timeout of 75000ms exceeded. 19 | await this.textAreaField.fill(value); 20 | } 21 | } 22 | 23 | private getLanguageButton(key: LanguageKey): Locator { 24 | return this.main.getByRole('button', { name: languages[key].name, exact: true }); 25 | } 26 | } 27 | ```