# 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-edit-general.spec.ts >> edits the email
- Location: src/manager/tests/e2e/customer/customer-edit-general.spec.ts:103:5

# 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: 2
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 2 elements
       - unexpected value "2"

```

# 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]: Icie83@yahoo.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 "2426-1859-9 Toby Wisoky Vienna South icie83@yahoo.com +43 814 7081949 Lead None 26 May 2026" [ref=e308]:
                  - cell "2426-1859-9" [ref=e309]:
                    - link "2426-1859-9" [ref=e310] [cursor=pointer]:
                      - /url: /customers/242618599
                      - generic [ref=e311]: 2426-1859-9
                  - cell "Toby Wisoky" [ref=e312]:
                    - link "Toby Wisoky" [ref=e313] [cursor=pointer]:
                      - /url: /customers/242618599
                      - generic [ref=e314]: Toby Wisoky
                  - cell "Vienna South" [ref=e315]:
                    - link "Vienna South" [ref=e316] [cursor=pointer]:
                      - /url: /customers/242618599
                      - generic [ref=e320]: Vienna South
                  - cell "icie83@yahoo.com" [ref=e321]:
                    - link "icie83@yahoo.com" [ref=e322] [cursor=pointer]:
                      - /url: /customers/242618599
                      - generic [ref=e325]: icie83@yahoo.com
                  - cell "+43 814 7081949" [ref=e326]:
                    - link "+43 814 7081949" [ref=e327] [cursor=pointer]:
                      - /url: /customers/242618599
                      - generic [ref=e330]: +43 814 7081949
                  - cell "Lead" [ref=e331]:
                    - link "Lead" [ref=e332] [cursor=pointer]:
                      - /url: /customers/242618599
                      - generic [ref=e335]: Lead
                  - cell "None" [ref=e336]:
                    - link "None" [ref=e337] [cursor=pointer]:
                      - /url: /customers/242618599
                      - generic [ref=e340]: None
                  - cell "26 May 2026" [ref=e341]:
                    - link "26 May 2026" [ref=e342] [cursor=pointer]:
                      - /url: /customers/242618599
                      - generic [ref=e343]: 26 May 2026
                - row "1020-1994-67 Dovie Padberg Storeroom Innsbruck City 1030 sauer.rosalia@yahoo.com +43 24224875067083572 Lead None 26 May 2026" [ref=e344]:
                  - cell "1020-1994-67" [ref=e345]:
                    - link "1020-1994-67" [ref=e346] [cursor=pointer]:
                      - /url: /customers/1020199467
                      - generic [ref=e347]: 1020-1994-67
                  - cell "Dovie Padberg" [ref=e348]:
                    - link "Dovie Padberg" [ref=e349] [cursor=pointer]:
                      - /url: /customers/1020199467
                      - generic [ref=e350]: Dovie Padberg
                  - cell "Storeroom Innsbruck City 1030" [ref=e351]:
                    - link "Storeroom Innsbruck City 1030" [ref=e352] [cursor=pointer]:
                      - /url: /customers/1020199467
                      - generic [ref=e354]:
                        - generic [ref=e356]: Storeroom Innsbruck
                        - generic [ref=e358]: City 1030
                  - cell "sauer.rosalia@yahoo.com" [ref=e359]:
                    - link "sauer.rosalia@yahoo.com" [ref=e360] [cursor=pointer]:
                      - /url: /customers/1020199467
                      - generic [ref=e363]: sauer.rosalia@yahoo.com
                  - cell "+43 24224875067083572" [ref=e364]:
                    - link "+43 24224875067083572" [ref=e365] [cursor=pointer]:
                      - /url: /customers/1020199467
                      - generic [ref=e368]: +43 24224875067083572
                  - cell "Lead" [ref=e369]:
                    - link "Lead" [ref=e370] [cursor=pointer]:
                      - /url: /customers/1020199467
                      - generic [ref=e373]: Lead
                  - cell "None" [ref=e374]:
                    - link "None" [ref=e375] [cursor=pointer]:
                      - /url: /customers/1020199467
                      - generic [ref=e378]: None
                  - cell "26 May 2026" [ref=e379]:
                    - link "26 May 2026" [ref=e380] [cursor=pointer]:
                      - /url: /customers/1020199467
                      - generic [ref=e381]: 26 May 2026
            - generic [ref=e384]:
              - generic [ref=e385]:
                - generic [ref=e386]: "Items per page:"
                - combobox [ref=e389]:
                  - generic [ref=e391] [cursor=pointer]:
                    - generic [ref=e393]: "10"
                    - combobox "Items per page:": "10"
                  - generic [ref=e395]: 󰍝
              - generic [ref=e396]: 1-2 of 2
              - generic [ref=e397]:
                - 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
  21  |     const newCustomer = applyCustomerEditGeneral(customer, tc.changes);
  22  |     const customerFullName = formatCustomerName(newCustomer.firstName, newCustomer.lastName);
  23  |     const customerTitle = newCustomer.type === 'business' ? newCustomer.companyName : customerFullName;
  24  |     const customerPhone = formatPhone(newCustomer.phone);
  25  |     const customerAddress = formatAddress(
  26  |       newCustomer.street,
  27  |       newCustomer.postalCode,
  28  |       newCustomer.city,
  29  |       newCustomer.country.name
  30  |     );
  31  |     const customerId = formatId(newCustomer.id, '-', 4);
  32  |     const customerCreatedAt = formatDate(newCustomer.createdAt);
  33  |     const customerLocationNames = newCustomer.locations.map((l) => l.name);
  34  | 
  35  |     await customerDetailsPage.goto(customer.id);
  36  | 
  37  |     const newDetailsPage = await test.step('edit customer general', async () => {
  38  |       const dialog = await customerDetailsPage.openCustomerEditGeneralDialog();
  39  |       return dialog.edit(tc.changes);
  40  |     });
  41  | 
  42  |     await test.step('verify new customer on details page', async () => {
  43  |       await expectSingleLocatorToHaveText(newDetailsPage.title, customerTitle);
  44  |       await expectSingleLocatorToHaveText(newDetailsPage.status, newCustomer.status);
  45  |       await expectMultiLocatorToHaveText(newDetailsPage.generalCard.locations, customerLocationNames);
  46  |       await expectSingleLocatorToHaveText(newDetailsPage.generalCard.type, newCustomer.type);
  47  | 
  48  |       if (newCustomer.type === 'business') {
  49  |         await expectSingleLocatorToHaveText(newDetailsPage.generalCard.companyName, newCustomer.companyName);
  50  |         await expectSingleLocatorToHaveText(newDetailsPage.generalCard.vatType, newCustomer.vatType?.name);
  51  |         await expectSingleLocatorToHaveText(newDetailsPage.generalCard.vatNumber, newCustomer.vatNumber);
  52  |       } else {
  53  |         await expect(newDetailsPage.generalCard.companyName).toBeHidden();
  54  |         await expect(newDetailsPage.generalCard.vatType).toBeHidden();
  55  |         await expect(newDetailsPage.generalCard.vatNumber).toBeHidden();
  56  |       }
  57  | 
  58  |       await expectSingleLocatorToHaveText(newDetailsPage.generalCard.name, customerFullName);
  59  |       await expectSingleLocatorToHaveText(newDetailsPage.generalCard.email, newCustomer.email);
  60  |       await expectSingleLocatorToHaveText(newDetailsPage.generalCard.phoneNumber, customerPhone);
  61  |       await expectSingleLocatorToHaveText(newDetailsPage.generalCard.language, newCustomer.language.id);
  62  |       await expectSingleLocatorToHaveText(newDetailsPage.generalCard.address, customerAddress);
  63  |       await expectSingleLocatorToHaveText(newDetailsPage.generalCard.note, newCustomer.note);
  64  |     });
  65  | 
  66  |     await test.step('verify new customer on list page', async () => {
  67  |       const listPage = await newDetailsPage.returnToCustomerListPage();
  68  | 
  69  |       await listPage.searchTextField.fill(newCustomer.email);
  70  | 
  71  |       await expect(listPage.dataTable.getRows()).toHaveCount(1);
  72  |       await expectDataTableTextColumnToHaveText(listPage.dataTable, customerTableColumnTestIds.id, customerId);
  73  |       await expectDataTableTextColumnToHaveText(listPage.dataTable, customerTableColumnTestIds.name, customerTitle);
  74  |       await expectDataTableChipsColumnToHaveText(
  75  |         listPage.dataTable,
  76  |         customerTableColumnTestIds.locations,
  77  |         customerLocationNames
  78  |       );
  79  |       await expectDataTableTextColumnToHaveText(
  80  |         listPage.dataTable,
  81  |         customerTableColumnTestIds.email,
  82  |         newCustomer.email
  83  |       );
  84  |       await expectDataTableTextColumnToHaveText(
  85  |         listPage.dataTable,
  86  |         customerTableColumnTestIds.phoneNumber,
  87  |         customerPhone
  88  |       );
  89  |       await expectDataTableChipsColumnToHaveText(
  90  |         listPage.dataTable,
  91  |         customerTableColumnTestIds.status,
  92  |         newCustomer.status
  93  |       );
  94  |       await expectDataTableTextColumnToHaveText(
  95  |         listPage.dataTable,
  96  |         customerTableColumnTestIds.createdAt,
  97  |         customerCreatedAt
  98  |       );
  99  |     });
  100 |   });
  101 | }
  102 | 
  103 | test('edits the email', async ({ createCustomer, customerDetailsPage }) => {
  104 |   const customer = await createCustomer(getCustomerCreateData());
  105 |   const newEmail = faker.internet.email();
  106 | 
  107 |   await customerDetailsPage.goto(customer.id);
  108 | 
  109 |   const newDetailsPage = await test.step('edit customer email', async () => {
  110 |     const dialog = await customerDetailsPage.openCustomerEditGeneralDialog();
  111 |     return dialog.edit({ email: newEmail });
  112 |   });
  113 | 
  114 |   await test.step('verify new email on details page', async () => {
  115 |     await expectSingleLocatorToHaveText(newDetailsPage.generalCard.email, newEmail);
  116 |   });
  117 | 
  118 |   await test.step('verify new email on list page', async () => {
  119 |     const listPage = await newDetailsPage.returnToCustomerListPage();
  120 |     await listPage.searchTextField.fill(newEmail);
> 121 |     await expect(listPage.dataTable.getRows()).toHaveCount(1);
      |                                                ^ Error: expect(locator).toHaveCount(expected) failed
  122 |   });
  123 | });
  124 | 
  125 | test('edits the phone number', async ({ createCustomer, customerDetailsPage }) => {
  126 |   const customer = await createCustomer(getCustomerCreateData());
  127 |   const newCountry = countries.BR;
  128 |   const newPhone = getCustomerPhone(newCountry);
  129 |   const formattedNewPhone = formatPhone(newPhone);
  130 | 
  131 |   await customerDetailsPage.goto(customer.id);
  132 | 
  133 |   const newDetailsPage = await test.step('edit customer phone number', async () => {
  134 |     const dialog = await customerDetailsPage.openCustomerEditGeneralDialog();
  135 |     return dialog.edit({ phone: newPhone, country: newCountry });
  136 |   });
  137 | 
  138 |   await test.step('verify new phone number on details page', async () => {
  139 |     await expectSingleLocatorToHaveText(newDetailsPage.generalCard.phoneNumber, formattedNewPhone);
  140 |   });
  141 | 
  142 |   await test.step('verify new phone number on list page', async () => {
  143 |     const listPage = await newDetailsPage.returnToCustomerListPage();
  144 |     await listPage.searchTextField.fill(formattedNewPhone);
  145 |     await expect(listPage.dataTable.getRows()).toHaveCount(1);
  146 |   });
  147 | });
  148 | 
  149 | test('rejects an edit with a duplicate email', async ({ createCustomer, customerDetailsPage }) => {
  150 |   const existing = await createCustomer(getCustomerCreateData());
  151 |   const editing = await createCustomer(getCustomerCreateData());
  152 | 
  153 |   await customerDetailsPage.goto(editing.id);
  154 | 
  155 |   const dialog = await test.step('submit edit with duplicate email', async () => {
  156 |     const editDialog = await customerDetailsPage.openCustomerEditGeneralDialog();
  157 |     await editDialog.fill({ email: existing.email });
  158 |     await editDialog.submit();
  159 |     return editDialog;
  160 |   });
  161 | 
  162 |   await test.step('verify errors on form', async () => {
  163 |     await expect(dialog.errors).toHaveCountGreaterThan(0);
  164 |   });
  165 | });
  166 | 
  167 | test('rejects an edit with a duplicate phone number', async ({ createCustomer, customerDetailsPage }) => {
  168 |   const existing = await createCustomer(getCustomerCreateData());
  169 |   const editing = await createCustomer(getCustomerCreateData());
  170 | 
  171 |   await customerDetailsPage.goto(editing.id);
  172 | 
  173 |   const dialog = await test.step('submit edit with duplicate phone number', async () => {
  174 |     const editDialog = await customerDetailsPage.openCustomerEditGeneralDialog();
  175 |     await editDialog.fill({ phone: existing.phone, country: existing.country });
  176 |     await editDialog.submit();
  177 |     return editDialog;
  178 |   });
  179 | 
  180 |   await test.step('verify errors on form', async () => {
  181 |     await expect(dialog.errors).toHaveCountGreaterThan(0);
  182 |   });
  183 | });
  184 | 
  185 | test('rejects an edit with a vat number that does not match the vat type', async ({
  186 |   createCustomer,
  187 |   customerDetailsPage,
  188 | }) => {
  189 |   const customer = await createCustomer(getCustomerCreateData({ type: 'business' }));
  190 | 
  191 |   await customerDetailsPage.goto(customer.id);
  192 | 
  193 |   const dialog = await test.step('submit edit with mismatched vat type and number', async () => {
  194 |     const editDialog = await customerDetailsPage.openCustomerEditGeneralDialog();
  195 |     await editDialog.fill({ vatType: vatTypes.eu_vat, vatNumber: 'INVALID-VAT-1234' });
  196 |     await editDialog.submit();
  197 |     return editDialog;
  198 |   });
  199 | 
  200 |   await test.step('verify errors on form', async () => {
  201 |     await expect(dialog.errors).toHaveCountGreaterThan(0);
  202 |   });
  203 | });
  204 | 
  205 | test('rejects an edit without all required fields', async ({ createCustomer, customerDetailsPage }) => {
  206 |   const customer = await createCustomer(getCustomerCreateData({ type: 'private' }));
  207 | 
  208 |   await customerDetailsPage.goto(customer.id);
  209 | 
  210 |   const dialog = await test.step('submit edit clearing required fields', async () => {
  211 |     const editDialog = await customerDetailsPage.openCustomerEditGeneralDialog();
  212 |     await editDialog.fill({ firstName: '', lastName: '' });
  213 |     await editDialog.submit();
  214 |     return editDialog;
  215 |   });
  216 | 
  217 |   await test.step('verify errors on form', async () => {
  218 |     await expect(dialog.errors).toHaveCountGreaterThan(0);
  219 |   });
  220 | });
  221 | 
```