# 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/customer/customer-create.spec.ts >> creates a customer with a note - Location: src/manager/tests/e2e/customer/customer-create.spec.ts:16:7 # Error details ``` Error: expect(locator).toHaveCount(expected) failed Locator: getByTestId('app-page').getByTestId('app-page-content').locator('.ui-data-grid').locator('[data-test-id=ui-data-grid-table]:not(.disabled):not(.loading):not(.fetching)').getByTestId('ui-data-grid-table-with-data').locator('tr') Expected: 1 Received: 10 Timeout: 20000ms Call log: - Expect "toHaveCount" with timeout 20000ms - waiting for getByTestId('app-page').getByTestId('app-page-content').locator('.ui-data-grid').locator('[data-test-id=ui-data-grid-table]:not(.disabled):not(.loading):not(.fetching)').getByTestId('ui-data-grid-table-with-data').locator('tr') 2 × locator resolved to 0 elements - unexpected value "0" 22 × locator resolved to 10 elements - unexpected value "10" ``` # Page snapshot ```yaml - generic [ref=e1]: - generic [ref=e6]: - navigation [ref=e7]: - generic [ref=e9]: - link [ref=e10] [cursor=pointer]: - /url: / - generic [ref=e11]: - generic [ref=e12]: KINNOVIS - generic [ref=e13]: - generic [ref=e14]: Manager - button [ref=e15] [cursor=pointer]: - img [ref=e16] - list [ref=e19]: - generic [ref=e21]: Dashboard - link "Tasks" [ref=e22] [cursor=pointer]: - /url: /tasks - img [ref=e25] - generic [ref=e28]: Tasks - link "Facility maps" [ref=e29] [cursor=pointer]: - /url: /facility-map - generic [ref=e31]: 󰧾 - generic [ref=e33]: Facility maps - link "Analytics" [ref=e34] [cursor=pointer]: - /url: /dashboard - generic [ref=e36]: 󱖶 - generic [ref=e38]: Analytics - generic [ref=e40]: Sales - link "Bookings" [ref=e41] [cursor=pointer]: - /url: /bookings - generic [ref=e43]: 󰇡 - generic [ref=e45]: Bookings - link "Customers" [ref=e46] [cursor=pointer]: - /url: /customers - generic [ref=e48]: 󰀏 - generic [ref=e50]: Customers - link "Invoices" [ref=e51] [cursor=pointer]: - /url: /invoices - generic [ref=e53]: 󰷉 - generic [ref=e55]: Invoices - link "Credit notes" [ref=e56] [cursor=pointer]: - /url: /credit-notes - img [ref=e59] - generic [ref=e62]: Credit notes - link "Units" [ref=e63] [cursor=pointer]: - /url: /units - generic [ref=e65]: 󰍀 - generic [ref=e67]: Units - generic [ref=e69]: Site management - link "Locations" [ref=e70] [cursor=pointer]: - /url: /locations - generic [ref=e72]: 󰟙 - generic [ref=e74]: Locations - link "Unit types" [ref=e75] [cursor=pointer]: - /url: /unit-types - generic [ref=e77]: 󰆧 - generic [ref=e79]: Unit types - link "Protection Plans" [ref=e80] [cursor=pointer]: - /url: /insurances - generic [ref=e82]: 󰳌 - generic [ref=e84]: Protection Plans - link "Deposits" [ref=e85] [cursor=pointer]: - /url: /deposits - generic [ref=e87]: 󱙆 - generic [ref=e89]: Deposits - link "Products" [ref=e90] [cursor=pointer]: - /url: /products - generic [ref=e92]: 󰄑 - generic [ref=e94]: Products - link "Discounts" [ref=e95] [cursor=pointer]: - /url: /discounts - generic [ref=e97]: 󰓼 - generic [ref=e99]: Discounts - generic [ref=e100]: - option "Emails" [ref=e101] [cursor=pointer]: - generic [ref=e103]: 󰻨 - generic [ref=e105]: Emails - generic [ref=e109]: 󰅀 - text: 󱡰 󰁥 - generic [ref=e111]: Admin - link "Integrations" [ref=e112] [cursor=pointer]: - /url: /connected-apps - generic [ref=e114]: 󱘖 - generic [ref=e116]: Integrations - link "User & Roles" [ref=e117] [cursor=pointer]: - /url: /users - generic [ref=e119]: 󰭘 - generic [ref=e121]: User & Roles - generic [ref=e122]: - option "Booking Portal" [ref=e123] [cursor=pointer]: - generic [ref=e125]: 󱃁 - generic [ref=e127]: Booking Portal - generic [ref=e131]: 󰅀 - text: 󰖟 󰟙 - generic [ref=e132]: - option "JaneAI" [ref=e133] [cursor=pointer]: - generic [ref=e135]: 󱙺 - generic [ref=e137]: JaneAI - generic [ref=e141]: 󰅀 - text: 󱜹 - generic [ref=e143]: Feedback - link "Voting Portal" [ref=e144] [cursor=pointer]: - /url: /voting-portal - generic [ref=e146]: 󰔔 - generic [ref=e148]: Voting Portal - generic [ref=e150]: - button "AS Andreas Stadler andreas.stadler@storeroom.at" [ref=e153] [cursor=pointer]: - generic [ref=e156]: AS - generic [ref=e157]: - generic [ref=e158]: Andreas Stadler - generic "andreas.stadler@storeroom.at" [ref=e159] - generic [ref=e160]: 󰇙 - generic: - text: 󰗊 󰅀 - text: 󰷖 󰍃 - button [ref=e161] [cursor=pointer]: - generic [ref=e163]: 󰋽 - main [ref=e164]: - generic [ref=e166]: - generic [ref=e168]: - generic [ref=e170]: Customers - generic [ref=e172]: - link "Create customer" [ref=e173] [cursor=pointer]: - /url: /customers/create - generic [ref=e174]: - generic [ref=e175]: 󰐕 - text: Create customer - button [ref=e176] [cursor=pointer]: - generic [ref=e180]: 󰍝 - generic [ref=e182]: - generic [ref=e184]: - button "Filters Reset filters" [ref=e185] [cursor=pointer]: - generic [ref=e186]: - heading "Filters" [level=3] [ref=e189] - generic [ref=e191]: - button "Reset filters" [ref=e193]: - generic [ref=e194]: - generic [ref=e195]: 󰑐 - text: Reset filters - generic [ref=e199]: 󰅀 - generic [ref=e205]: - generic [ref=e210]: - generic [ref=e212]: 󰍉 - textbox "Search" [active] [ref=e214]: Adelbert.Donnelly39@hotmail.com - button "Clear Search" [ref=e216] [cursor=pointer]: 󰅙 - generic: - generic: Search - combobox [ref=e220]: - generic [ref=e221]: - generic: Location - combobox "Location" [ref=e223] - button [ref=e225] [cursor=pointer]: 󰍝 - combobox [ref=e229]: - generic [ref=e230]: - generic: Has past due invoice(s) - combobox "Has past due invoice(s)" [ref=e232] - button [ref=e234] [cursor=pointer]: 󰍝 - combobox [ref=e238]: - generic [ref=e239]: - generic: Status - combobox "Status" [ref=e241] - button [ref=e243] [cursor=pointer]: 󰍝 - generic [ref=e245]: - table [ref=e249]: - rowgroup [ref=e250]: - row "Customer no. Name Location(s) Email address Phone number Status Past due invoice(s) Created at" [ref=e251]: - columnheader "Customer no." [ref=e252]: - button "Customer no." [ref=e253] [cursor=pointer]: - generic [ref=e255]: Customer no. - generic [ref=e258]: 󰁝 - columnheader "Name" [ref=e259]: - button "Name" [ref=e260] [cursor=pointer]: - generic [ref=e262]: Name - generic [ref=e265]: 󰁝 - columnheader "Location(s)" [ref=e266]: - button "Location(s)" [ref=e267] [cursor=pointer]: - generic [ref=e269]: Location(s) - generic [ref=e272]: 󰁝 - columnheader "Email address" [ref=e273]: - button "Email address" [ref=e274] [cursor=pointer]: - generic [ref=e276]: Email address - generic [ref=e279]: 󰁝 - columnheader "Phone number" [ref=e280]: - generic [ref=e283]: Phone number - columnheader "Status" [ref=e284]: - button "Status" [ref=e285] [cursor=pointer]: - generic [ref=e287]: Status - generic [ref=e290]: 󰁝 - columnheader "Past due invoice(s)" [ref=e291]: - button "Past due invoice(s)" [ref=e292] [cursor=pointer]: - generic [ref=e294]: Past due invoice(s) - generic [ref=e297]: 󰁝 - columnheader "Created at" [ref=e298]: - button "Created at" [ref=e299] [cursor=pointer]: - generic [ref=e301]: Created at - generic [ref=e304]: 󰁝 - row [ref=e305]: - columnheader [ref=e306] - rowgroup [ref=e307]: - row "5547-2778 Sharon Renner Storeroom Innsbruck Vienna North Vienna South bryan_bogisich@hotmail.com +43 7190 390368 Lead None 26 May 2026" [ref=e308]: - cell "5547-2778" [ref=e309]: - link "5547-2778" [ref=e310] [cursor=pointer]: - /url: /customers/55472778 - generic [ref=e311]: 5547-2778 - cell "Sharon Renner" [ref=e312]: - link "Sharon Renner" [ref=e313] [cursor=pointer]: - /url: /customers/55472778 - generic [ref=e314]: Sharon Renner - cell "Storeroom Innsbruck Vienna North Vienna South" [ref=e315]: - link "Storeroom Innsbruck Vienna North Vienna South" [ref=e316] [cursor=pointer]: - /url: /customers/55472778 - generic [ref=e318]: - generic [ref=e320]: Storeroom Innsbruck - generic [ref=e322]: Vienna North - generic [ref=e324]: Vienna South - cell "bryan_bogisich@hotmail.com" [ref=e325]: - link "bryan_bogisich@hotmail.com" [ref=e326] [cursor=pointer]: - /url: /customers/55472778 - generic [ref=e329]: bryan_bogisich@hotmail.com - cell "+43 7190 390368" [ref=e330]: - link "+43 7190 390368" [ref=e331] [cursor=pointer]: - /url: /customers/55472778 - generic [ref=e334]: +43 7190 390368 - cell "Lead" [ref=e335]: - link "Lead" [ref=e336] [cursor=pointer]: - /url: /customers/55472778 - generic [ref=e339]: Lead - cell "None" [ref=e340]: - link "None" [ref=e341] [cursor=pointer]: - /url: /customers/55472778 - generic [ref=e344]: None - cell "26 May 2026" [ref=e345]: - link "26 May 2026" [ref=e346] [cursor=pointer]: - /url: /customers/55472778 - generic [ref=e347]: 26 May 2026 - row "1374-7085-82 Annabelle Strosin Vienna South adelbert.donnelly39@hotmail.com +43 6399 257205 Lead None 26 May 2026" [ref=e348]: - cell "1374-7085-82" [ref=e349]: - link "1374-7085-82" [ref=e350] [cursor=pointer]: - /url: /customers/1374708582 - generic [ref=e351]: 1374-7085-82 - cell "Annabelle Strosin" [ref=e352]: - link "Annabelle Strosin" [ref=e353] [cursor=pointer]: - /url: /customers/1374708582 - generic [ref=e354]: Annabelle Strosin - cell "Vienna South" [ref=e355]: - link "Vienna South" [ref=e356] [cursor=pointer]: - /url: /customers/1374708582 - generic [ref=e360]: Vienna South - cell "adelbert.donnelly39@hotmail.com" [ref=e361]: - link "adelbert.donnelly39@hotmail.com" [ref=e362] [cursor=pointer]: - /url: /customers/1374708582 - generic [ref=e365]: adelbert.donnelly39@hotmail.com - cell "+43 6399 257205" [ref=e366]: - link "+43 6399 257205" [ref=e367] [cursor=pointer]: - /url: /customers/1374708582 - generic [ref=e370]: +43 6399 257205 - cell "Lead" [ref=e371]: - link "Lead" [ref=e372] [cursor=pointer]: - /url: /customers/1374708582 - generic [ref=e375]: Lead - cell "None" [ref=e376]: - link "None" [ref=e377] [cursor=pointer]: - /url: /customers/1374708582 - generic [ref=e380]: None - cell "26 May 2026" [ref=e381]: - link "26 May 2026" [ref=e382] [cursor=pointer]: - /url: /customers/1374708582 - generic [ref=e383]: 26 May 2026 - row "1424-5788-77 Clemmie Bogisich Vienna South cole.morissette@yahoo.com +43 98453762749079096 Lead None 26 May 2026" [ref=e384]: - cell "1424-5788-77" [ref=e385]: - link "1424-5788-77" [ref=e386] [cursor=pointer]: - /url: /customers/1424578877 - generic [ref=e387]: 1424-5788-77 - cell "Clemmie Bogisich" [ref=e388]: - link "Clemmie Bogisich" [ref=e389] [cursor=pointer]: - /url: /customers/1424578877 - generic [ref=e390]: Clemmie Bogisich - cell "Vienna South" [ref=e391]: - link "Vienna South" [ref=e392] [cursor=pointer]: - /url: /customers/1424578877 - generic [ref=e396]: Vienna South - cell "cole.morissette@yahoo.com" [ref=e397]: - link "cole.morissette@yahoo.com" [ref=e398] [cursor=pointer]: - /url: /customers/1424578877 - generic [ref=e401]: cole.morissette@yahoo.com - cell "+43 98453762749079096" [ref=e402]: - link "+43 98453762749079096" [ref=e403] [cursor=pointer]: - /url: /customers/1424578877 - generic [ref=e406]: +43 98453762749079096 - cell "Lead" [ref=e407]: - link "Lead" [ref=e408] [cursor=pointer]: - /url: /customers/1424578877 - generic [ref=e411]: Lead - cell "None" [ref=e412]: - link "None" [ref=e413] [cursor=pointer]: - /url: /customers/1424578877 - generic [ref=e416]: None - cell "26 May 2026" [ref=e417]: - link "26 May 2026" [ref=e418] [cursor=pointer]: - /url: /customers/1424578877 - generic [ref=e419]: 26 May 2026 - row "3966-8131 Carmella Davis Vienna North iskiles@yahoo.com +43 97792803633022467 Lead None 26 May 2026" [ref=e420]: - cell "3966-8131" [ref=e421]: - link "3966-8131" [ref=e422] [cursor=pointer]: - /url: /customers/39668131 - generic [ref=e423]: 3966-8131 - cell "Carmella Davis" [ref=e424]: - link "Carmella Davis" [ref=e425] [cursor=pointer]: - /url: /customers/39668131 - generic [ref=e426]: Carmella Davis - cell "Vienna North" [ref=e427]: - link "Vienna North" [ref=e428] [cursor=pointer]: - /url: /customers/39668131 - generic [ref=e432]: Vienna North - cell "iskiles@yahoo.com" [ref=e433]: - link "iskiles@yahoo.com" [ref=e434] [cursor=pointer]: - /url: /customers/39668131 - generic [ref=e437]: iskiles@yahoo.com - cell "+43 97792803633022467" [ref=e438]: - link "+43 97792803633022467" [ref=e439] [cursor=pointer]: - /url: /customers/39668131 - generic [ref=e442]: +43 97792803633022467 - cell "Lead" [ref=e443]: - link "Lead" [ref=e444] [cursor=pointer]: - /url: /customers/39668131 - generic [ref=e447]: Lead - cell "None" [ref=e448]: - link "None" [ref=e449] [cursor=pointer]: - /url: /customers/39668131 - generic [ref=e452]: None - cell "26 May 2026" [ref=e453]: - link "26 May 2026" [ref=e454] [cursor=pointer]: - /url: /customers/39668131 - generic [ref=e455]: 26 May 2026 - row "5119-4629 Marquardt, Bahringer and Kuphal Vienna South quincy90@yahoo.com +43 91290024922826540 Lead None 26 May 2026" [ref=e456]: - cell "5119-4629" [ref=e457]: - link "5119-4629" [ref=e458] [cursor=pointer]: - /url: /customers/51194629 - generic [ref=e459]: 5119-4629 - cell "Marquardt, Bahringer and Kuphal" [ref=e460]: - link "Marquardt, Bahringer and Kuphal" [ref=e461] [cursor=pointer]: - /url: /customers/51194629 - generic [ref=e462]: Marquardt, Bahringer and Kuphal - cell "Vienna South" [ref=e463]: - link "Vienna South" [ref=e464] [cursor=pointer]: - /url: /customers/51194629 - generic [ref=e468]: Vienna South - cell "quincy90@yahoo.com" [ref=e469]: - link "quincy90@yahoo.com" [ref=e470] [cursor=pointer]: - /url: /customers/51194629 - generic [ref=e473]: quincy90@yahoo.com - cell "+43 91290024922826540" [ref=e474]: - link "+43 91290024922826540" [ref=e475] [cursor=pointer]: - /url: /customers/51194629 - generic [ref=e478]: +43 91290024922826540 - cell "Lead" [ref=e479]: - link "Lead" [ref=e480] [cursor=pointer]: - /url: /customers/51194629 - generic [ref=e483]: Lead - cell "None" [ref=e484]: - link "None" [ref=e485] [cursor=pointer]: - /url: /customers/51194629 - generic [ref=e488]: None - cell "26 May 2026" [ref=e489]: - link "26 May 2026" [ref=e490] [cursor=pointer]: - /url: /customers/51194629 - generic [ref=e491]: 26 May 2026 - row "1750-6912-50 Dorian Murphy Vienna North ivah.dickens@emmerich.biz +43 93482169191863890 Lead None 26 May 2026" [ref=e492]: - cell "1750-6912-50" [ref=e493]: - link "1750-6912-50" [ref=e494] [cursor=pointer]: - /url: /customers/1750691250 - generic [ref=e495]: 1750-6912-50 - cell "Dorian Murphy" [ref=e496]: - link "Dorian Murphy" [ref=e497] [cursor=pointer]: - /url: /customers/1750691250 - generic [ref=e498]: Dorian Murphy - cell "Vienna North" [ref=e499]: - link "Vienna North" [ref=e500] [cursor=pointer]: - /url: /customers/1750691250 - generic [ref=e504]: Vienna North - cell "ivah.dickens@emmerich.biz" [ref=e505]: - link "ivah.dickens@emmerich.biz" [ref=e506] [cursor=pointer]: - /url: /customers/1750691250 - generic [ref=e509]: ivah.dickens@emmerich.biz - cell "+43 93482169191863890" [ref=e510]: - link "+43 93482169191863890" [ref=e511] [cursor=pointer]: - /url: /customers/1750691250 - generic [ref=e514]: +43 93482169191863890 - cell "Lead" [ref=e515]: - link "Lead" [ref=e516] [cursor=pointer]: - /url: /customers/1750691250 - generic [ref=e519]: Lead - cell "None" [ref=e520]: - link "None" [ref=e521] [cursor=pointer]: - /url: /customers/1750691250 - generic [ref=e524]: None - cell "26 May 2026" [ref=e525]: - link "26 May 2026" [ref=e526] [cursor=pointer]: - /url: /customers/1750691250 - generic [ref=e527]: 26 May 2026 - row "1715-1629-04 Kuhic, Klocko and Zboncak Vienna South tillman.holly@wyman.net +43 93675340743382226 Lead None 26 May 2026" [ref=e528]: - cell "1715-1629-04" [ref=e529]: - link "1715-1629-04" [ref=e530] [cursor=pointer]: - /url: /customers/1715162904 - generic [ref=e531]: 1715-1629-04 - cell "Kuhic, Klocko and Zboncak" [ref=e532]: - link "Kuhic, Klocko and Zboncak" [ref=e533] [cursor=pointer]: - /url: /customers/1715162904 - generic [ref=e534]: Kuhic, Klocko and Zboncak - cell "Vienna South" [ref=e535]: - link "Vienna South" [ref=e536] [cursor=pointer]: - /url: /customers/1715162904 - generic [ref=e540]: Vienna South - cell "tillman.holly@wyman.net" [ref=e541]: - link "tillman.holly@wyman.net" [ref=e542] [cursor=pointer]: - /url: /customers/1715162904 - generic [ref=e545]: tillman.holly@wyman.net - cell "+43 93675340743382226" [ref=e546]: - link "+43 93675340743382226" [ref=e547] [cursor=pointer]: - /url: /customers/1715162904 - generic [ref=e550]: +43 93675340743382226 - cell "Lead" [ref=e551]: - link "Lead" [ref=e552] [cursor=pointer]: - /url: /customers/1715162904 - generic [ref=e555]: Lead - cell "None" [ref=e556]: - link "None" [ref=e557] [cursor=pointer]: - /url: /customers/1715162904 - generic [ref=e560]: None - cell "26 May 2026" [ref=e561]: - link "26 May 2026" [ref=e562] [cursor=pointer]: - /url: /customers/1715162904 - generic [ref=e563]: 26 May 2026 - row "9020-5377-3 Brakus-Gibson Vienna North eli93@walker.com +43 90709459691719964 Lead None 26 May 2026" [ref=e564]: - cell "9020-5377-3" [ref=e565]: - link "9020-5377-3" [ref=e566] [cursor=pointer]: - /url: /customers/902053773 - generic [ref=e567]: 9020-5377-3 - cell "Brakus-Gibson" [ref=e568]: - link "Brakus-Gibson" [ref=e569] [cursor=pointer]: - /url: /customers/902053773 - generic [ref=e570]: Brakus-Gibson - cell "Vienna North" [ref=e571]: - link "Vienna North" [ref=e572] [cursor=pointer]: - /url: /customers/902053773 - generic [ref=e576]: Vienna North - cell "eli93@walker.com" [ref=e577]: - link "eli93@walker.com" [ref=e578] [cursor=pointer]: - /url: /customers/902053773 - generic [ref=e581]: eli93@walker.com - cell "+43 90709459691719964" [ref=e582]: - link "+43 90709459691719964" [ref=e583] [cursor=pointer]: - /url: /customers/902053773 - generic [ref=e586]: +43 90709459691719964 - cell "Lead" [ref=e587]: - link "Lead" [ref=e588] [cursor=pointer]: - /url: /customers/902053773 - generic [ref=e591]: Lead - cell "None" [ref=e592]: - link "None" [ref=e593] [cursor=pointer]: - /url: /customers/902053773 - generic [ref=e596]: None - cell "26 May 2026" [ref=e597]: - link "26 May 2026" [ref=e598] [cursor=pointer]: - /url: /customers/902053773 - generic [ref=e599]: 26 May 2026 - row "7638-9607-8 Charlotte Denesik Vienna South marina89@cremin.com +43 55239239650437551 Lead None 26 May 2026" [ref=e600]: - cell "7638-9607-8" [ref=e601]: - link "7638-9607-8" [ref=e602] [cursor=pointer]: - /url: /customers/763896078 - generic [ref=e603]: 7638-9607-8 - cell "Charlotte Denesik" [ref=e604]: - link "Charlotte Denesik" [ref=e605] [cursor=pointer]: - /url: /customers/763896078 - generic [ref=e606]: Charlotte Denesik - cell "Vienna South" [ref=e607]: - link "Vienna South" [ref=e608] [cursor=pointer]: - /url: /customers/763896078 - generic [ref=e612]: Vienna South - cell "marina89@cremin.com" [ref=e613]: - link "marina89@cremin.com" [ref=e614] [cursor=pointer]: - /url: /customers/763896078 - generic [ref=e617]: marina89@cremin.com - cell "+43 55239239650437551" [ref=e618]: - link "+43 55239239650437551" [ref=e619] [cursor=pointer]: - /url: /customers/763896078 - generic [ref=e622]: +43 55239239650437551 - cell "Lead" [ref=e623]: - link "Lead" [ref=e624] [cursor=pointer]: - /url: /customers/763896078 - generic [ref=e627]: Lead - cell "None" [ref=e628]: - link "None" [ref=e629] [cursor=pointer]: - /url: /customers/763896078 - generic [ref=e632]: None - cell "26 May 2026" [ref=e633]: - link "26 May 2026" [ref=e634] [cursor=pointer]: - /url: /customers/763896078 - generic [ref=e635]: 26 May 2026 - row "9712-4931-2 Champlin-Klein Vienna South cremin.brent@schroeder.biz +43 62393381959681441 Lead None 26 May 2026" [ref=e636]: - cell "9712-4931-2" [ref=e637]: - link "9712-4931-2" [ref=e638] [cursor=pointer]: - /url: /customers/971249312 - generic [ref=e639]: 9712-4931-2 - cell "Champlin-Klein" [ref=e640]: - link "Champlin-Klein" [ref=e641] [cursor=pointer]: - /url: /customers/971249312 - generic [ref=e642]: Champlin-Klein - cell "Vienna South" [ref=e643]: - link "Vienna South" [ref=e644] [cursor=pointer]: - /url: /customers/971249312 - generic [ref=e648]: Vienna South - cell "cremin.brent@schroeder.biz" [ref=e649]: - link "cremin.brent@schroeder.biz" [ref=e650] [cursor=pointer]: - /url: /customers/971249312 - generic [ref=e653]: cremin.brent@schroeder.biz - cell "+43 62393381959681441" [ref=e654]: - link "+43 62393381959681441" [ref=e655] [cursor=pointer]: - /url: /customers/971249312 - generic [ref=e658]: +43 62393381959681441 - cell "Lead" [ref=e659]: - link "Lead" [ref=e660] [cursor=pointer]: - /url: /customers/971249312 - generic [ref=e663]: Lead - cell "None" [ref=e664]: - link "None" [ref=e665] [cursor=pointer]: - /url: /customers/971249312 - generic [ref=e668]: None - cell "26 May 2026" [ref=e669]: - link "26 May 2026" [ref=e670] [cursor=pointer]: - /url: /customers/971249312 - generic [ref=e671]: 26 May 2026 - generic [ref=e674]: - generic [ref=e675]: - generic [ref=e676]: "Items per page:" - combobox [ref=e679]: - generic [ref=e681] [cursor=pointer]: - generic [ref=e683]: "10" - combobox "Items per page:": "10" - generic [ref=e685]: 󰍝 - generic [ref=e686]: 1-10 of 10 - generic [ref=e687]: - 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 - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip - tooltip ``` # Test source ```ts 1 | import { getCustomerCreateData } from '@/manager/modules/customer/customer-factories'; 2 | import { test } from '@/manager/modules/customer/customer-fixtures'; 3 | import { formatCustomerName } from '@/manager/modules/customer/customer-utils'; 4 | import { customerCreateHappyTestCases } from '@/manager/modules/customer/test-cases/customer-create-happy-test-cases'; 5 | import { 6 | expectDataTableChipsColumnToHaveText, 7 | expectDataTableTextColumnToHaveText, 8 | } from '@/manager/modules/ui/data-table/data-table-assertions'; 9 | import { customerTableColumnTestIds } from '@/manager/modules/ui/data-table/data/data-table-column-test-ids'; 10 | import { expectMultiLocatorToHaveText, expectSingleLocatorToHaveText } from '@/manager/shared/utils/expect-utils'; 11 | import { vatTypes } from '@/shared/data/seed-vat-types'; 12 | import { formatAddress, formatCurrency, formatDate, formatPhone } from '@/shared/utils/formatters'; 13 | import { expect } from '@/shared/utils/matchers'; 14 | 15 | for (const tc of customerCreateHappyTestCases) { 16 | test(tc.description, async ({ customerCreateDialog, trackCustomerForTeardown }) => { 17 | const data = getCustomerCreateData(tc.options); 18 | const customerFullName = formatCustomerName(data.firstName, data.lastName); 19 | const customerTitle = data.type === 'business' ? data.companyName : customerFullName; 20 | const customerPhone = formatPhone(data.phone); 21 | const customerAddress = formatAddress(data.street, data.postalCode, data.city, data.country.name); 22 | const customerStatus = 'lead'; 23 | const customerCreatedAt = formatDate(new Date()); 24 | const customerCurrency = data.locations[0].currency; 25 | const customerLocationNames = data.locations.map((l) => l.name); 26 | const zeroAmount = formatCurrency(0, customerCurrency); 27 | 28 | await customerCreateDialog.goto(); 29 | 30 | const detailsPage = await test.step('create customer', () => customerCreateDialog.create(data)); 31 | 32 | trackCustomerForTeardown(detailsPage.getCustomerId()); 33 | 34 | await test.step('verify new customer on details page', async () => { 35 | await expectSingleLocatorToHaveText(detailsPage.title, customerTitle); 36 | await expectSingleLocatorToHaveText(detailsPage.status, customerStatus); 37 | await expectMultiLocatorToHaveText(detailsPage.generalCard.locations, customerLocationNames); 38 | await expectSingleLocatorToHaveText(detailsPage.generalCard.type, data.type); 39 | 40 | if (data.type === 'business') { 41 | await expectSingleLocatorToHaveText(detailsPage.generalCard.companyName, data.companyName); 42 | await expectSingleLocatorToHaveText(detailsPage.generalCard.vatType, data.vatType?.name); 43 | await expectSingleLocatorToHaveText(detailsPage.generalCard.vatNumber, data.vatNumber); 44 | } else { 45 | await expect(detailsPage.generalCard.companyName).toBeHidden(); 46 | await expect(detailsPage.generalCard.vatType).toBeHidden(); 47 | await expect(detailsPage.generalCard.vatNumber).toBeHidden(); 48 | } 49 | 50 | await expectSingleLocatorToHaveText(detailsPage.generalCard.name, customerFullName); 51 | await expectSingleLocatorToHaveText(detailsPage.generalCard.email, data.email); 52 | await expectSingleLocatorToHaveText(detailsPage.generalCard.phoneNumber, customerPhone); 53 | await expectSingleLocatorToHaveText(detailsPage.generalCard.language, data.language.id); 54 | await expectSingleLocatorToHaveText(detailsPage.generalCard.address, customerAddress); 55 | await expectSingleLocatorToHaveText(detailsPage.generalCard.note, data.note); 56 | 57 | await expect(detailsPage.detailsCard.customerId).not.toBeEmpty(); 58 | await expectSingleLocatorToHaveText(detailsPage.detailsCard.createdAt, customerCreatedAt); 59 | await expectSingleLocatorToHaveText(detailsPage.detailsCard.totalSpent, zeroAmount); 60 | await expectSingleLocatorToHaveText(detailsPage.detailsCard.totalPastDueAmount, zeroAmount); 61 | await expect(detailsPage.detailsCard.paymentMethods).toHaveCount(0); 62 | await expectSingleLocatorToHaveText( 63 | detailsPage.detailsCard.accountsReceivableNumber, 64 | data.accountsReceivableNumber 65 | ); 66 | 67 | await expect(detailsPage.bookingsCard.main).toBeHidden(); 68 | await expect(detailsPage.invoicesCard.main).toBeHidden(); 69 | }); 70 | 71 | await test.step('verify new customer on list page', async () => { 72 | const listPage = await detailsPage.returnToCustomerListPage(); 73 | 74 | await listPage.searchTextField.fill(data.email); 75 | > 76 | await expect(listPage.dataTable.getRows()).toHaveCount(1); | ^ Error: expect(locator).toHaveCount(expected) failed 77 | await expect(listPage.dataTable.getRowColumn(0, customerTableColumnTestIds.id)).not.toBeEmpty(); 78 | await expectDataTableTextColumnToHaveText(listPage.dataTable, customerTableColumnTestIds.name, customerTitle); 79 | await expectDataTableChipsColumnToHaveText( 80 | listPage.dataTable, 81 | customerTableColumnTestIds.locations, 82 | customerLocationNames 83 | ); 84 | await expectDataTableTextColumnToHaveText(listPage.dataTable, customerTableColumnTestIds.email, data.email); 85 | await expectDataTableTextColumnToHaveText( 86 | listPage.dataTable, 87 | customerTableColumnTestIds.phoneNumber, 88 | customerPhone 89 | ); 90 | await expectDataTableChipsColumnToHaveText(listPage.dataTable, customerTableColumnTestIds.status, customerStatus); 91 | await expectDataTableChipsColumnToHaveText( 92 | listPage.dataTable, 93 | customerTableColumnTestIds.hasPastDueInvoices, 94 | 'none' 95 | ); 96 | await expectDataTableTextColumnToHaveText( 97 | listPage.dataTable, 98 | customerTableColumnTestIds.createdAt, 99 | customerCreatedAt 100 | ); 101 | }); 102 | }); 103 | } 104 | 105 | test('rejects a private customer without all required fields', async ({ customerCreateDialog }) => { 106 | const data = getCustomerCreateData({ type: 'private', firstName: '', lastName: '' }); 107 | 108 | await customerCreateDialog.goto(); 109 | 110 | await test.step('submit invalid customer create form', async () => { 111 | await customerCreateDialog.fill(data); 112 | await customerCreateDialog.submit(); 113 | }); 114 | 115 | await test.step('verify errors on form', async () => { 116 | await expect(customerCreateDialog.errors).toHaveCountGreaterThan(0); 117 | }); 118 | }); 119 | 120 | test('rejects a business customer without all required fields', async ({ customerCreateDialog }) => { 121 | const data = getCustomerCreateData({ type: 'business', companyName: '' }); 122 | 123 | await customerCreateDialog.goto(); 124 | 125 | await test.step('submit invalid customer create form', async () => { 126 | await customerCreateDialog.fill(data); 127 | await customerCreateDialog.submit(); 128 | }); 129 | 130 | await test.step('verify errors on form', async () => { 131 | await expect(customerCreateDialog.errors).toHaveCountGreaterThan(0); 132 | }); 133 | }); 134 | 135 | test('rejects a customer with a duplicate email', async ({ createCustomer, customerCreateDialog }) => { 136 | const existing = await createCustomer(getCustomerCreateData()); 137 | const data = getCustomerCreateData({ email: existing.email }); 138 | 139 | await customerCreateDialog.goto(); 140 | 141 | await test.step('submit customer create form with duplicate email', async () => { 142 | await customerCreateDialog.fill(data); 143 | await customerCreateDialog.submit(); 144 | }); 145 | 146 | await test.step('verify errors on form', async () => { 147 | await expect(customerCreateDialog.errors).toHaveCountGreaterThan(0); 148 | }); 149 | }); 150 | 151 | test('rejects a customer with a duplicate phone number', async ({ createCustomer, customerCreateDialog }) => { 152 | const existing = await createCustomer(getCustomerCreateData()); 153 | const data = getCustomerCreateData({ phone: existing.phone, country: existing.country }); 154 | 155 | await customerCreateDialog.goto(); 156 | 157 | await test.step('submit customer create form with duplicate phone number', async () => { 158 | await customerCreateDialog.fill(data); 159 | await customerCreateDialog.submit(); 160 | }); 161 | 162 | await test.step('verify errors on form', async () => { 163 | await expect(customerCreateDialog.errors).toHaveCountGreaterThan(0); 164 | }); 165 | }); 166 | 167 | test('rejects a customer with a vat number that does not match the vat type', async ({ customerCreateDialog }) => { 168 | const data = getCustomerCreateData({ 169 | type: 'business', 170 | vatType: vatTypes.eu_vat, 171 | vatNumber: 'INVALID-VAT-1234', 172 | }); 173 | 174 | await customerCreateDialog.goto(); 175 | 176 | await test.step('submit customer create form with mismatched vat type and number', async () => { ```