dimsum-e2e-tests 3.50.1-next.9 → 3.51.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (119) hide show
  1. package/CHANGELOG.md +268 -310
  2. package/ds-autocomplete/DSAutocompleteCO.js +1 -1
  3. package/ds-banner/DSBanner.func.spec.js +55 -0
  4. package/ds-banner/DSBanner.visual.spec.js +14 -0
  5. package/ds-banner/DSBannerCO.js +30 -0
  6. package/ds-breadcrumb/DSBreadcrumb.axe-core.func.spec.js +21 -6
  7. package/ds-breadcrumb/DSBreadcrumb.func.spec.js +69 -40
  8. package/ds-breadcrumb/DSBreadcrumb.visual.spec.js +20 -15
  9. package/ds-breadcrumb/DSBreadcrumbCO.js +17 -1
  10. package/ds-button-v3/DSButtonV3.func.spec.js +22 -0
  11. package/ds-button-v3/DSButtonV3.visual.spec.js +8 -2
  12. package/ds-button-v3/DSButtonV3CO.js +14 -0
  13. package/ds-card-v3/DSCardV3CO.js +10 -10
  14. package/ds-card-v3/global-attributes/DSCardV3.global-attributes.func.spec.js +4 -4
  15. package/ds-comments-card/DSComments.visual.spec.js +3 -4
  16. package/ds-comments-card/DSCommentsCO.js +2 -2
  17. package/ds-controlled-form/ds-combobox/DSCombobox.func.spec.js +1 -0
  18. package/ds-controlled-form/ds-combobox/DSCombobox.smoke.spec.js +4 -56
  19. package/ds-controlled-form/ds-combobox/DSComboboxCO.js +0 -9
  20. package/ds-controlled-form/ds-combobox/creatable/DSCombobox.keyboard-creatable.func.spec.js +3 -0
  21. package/ds-controlled-form/ds-combobox/inline/DSCombobox.inline.axe-core.spec.js +0 -1
  22. package/ds-controlled-form/ds-combobox/inline/DSCombobox.inline.keyboard.func.spec.js +5 -0
  23. package/ds-controlled-form/ds-combobox/multi-select/DSCombobox.keyboard-multi-select.func.spec.js +6 -68
  24. package/ds-controlled-form/ds-combobox/multi-select/DSCombobox.mouse-touch-multi-select.func.spec.js +0 -58
  25. package/ds-controlled-form/ds-combobox/multi-select/DSCombobox.multi.visual.spec.js +1 -16
  26. package/ds-controlled-form/ds-combobox/multi-select/DSCombobox.ten-thousand-options.func.spec.js +2 -22
  27. package/ds-controlled-form/ds-combobox/single-select/DSCombobox.keyboard-single-select.func.spec.js +4 -0
  28. package/ds-controlled-form/ds-controlled-date-range-picker/DSControlledDateRangePicker.axe-core.spec.js +85 -0
  29. package/ds-controlled-form/ds-controlled-date-range-picker/DSControlledDateRangePicker.functional.spec.js +242 -0
  30. package/ds-controlled-form/ds-controlled-date-range-picker/DSControlledDateRangePicker.visual.spec.js +115 -0
  31. package/ds-controlled-form/ds-controlled-date-range-picker/DSControlledDateRangePickerCO.js +56 -2
  32. package/ds-controlled-form/ds-controlled-date-range-picker/read-only/DSControlledDateRangePicker.ReadOnly.axe-core.spec.js +17 -0
  33. package/ds-controlled-form/ds-controlled-date-time-picker/DSControlledDateTimePickerCO.js +12 -0
  34. package/ds-controlled-form/ds-controlled-date-time-picker/date-full/DateFull.axe-core.func.spec.js +27 -0
  35. package/ds-controlled-form/ds-controlled-date-time-picker/date-input/DateInput.axe-core.func.spec.js +27 -0
  36. package/ds-controlled-form/ds-controlled-date-time-picker/date-time-full/DateTimeFull.axe-core.func.spec.js +27 -0
  37. package/ds-controlled-form/ds-controlled-date-time-picker/date-time-input/DateTimeInput.axe-core.func.spec.js +27 -0
  38. package/ds-controlled-form/ds-controlled-date-time-picker/time-full/TimeFull.axe-core.func.spec.js +27 -0
  39. package/ds-controlled-form/ds-controlled-date-time-picker/time-input/TimeInput.axe-core.func.spec.js +27 -0
  40. package/ds-controlled-form/ds-controlled-inputgroup/DSControlledInputGroupCO.js +4 -0
  41. package/ds-controlled-form/ds-controlled-inputgroup/autocomplete/DSControlledInputGroup.autocomplete.axe-core.func.spec.js +1 -0
  42. package/ds-controlled-form/ds-controlled-inputgroup/combobox/DSControlledInputGroup.combobox.axe-core.func.spec.js +1 -1
  43. package/ds-controlled-form/ds-controlled-large-input-text/DSLargeInputTextCO.js +4 -4
  44. package/ds-controlled-form/ds-controlled-large-input-text/read-only/DSLargeInputText.read-only.axe-core.func.spec.js +1 -1
  45. package/ds-controlled-form/ds-controlled-large-input-text/read-only/DSLargeInputText.read-only.func.spec.js +36 -0
  46. package/ds-controlled-form/ds-controlled-large-input-text/read-only/DSLargeInputText.read-only.visual.spec.js +12 -1
  47. package/ds-controlled-form/ds-input-text/DSInputText.func.spec.js +14 -12
  48. package/ds-controlled-form/react-hook-form/ReactHook.visual.spec.js +1 -0
  49. package/ds-data-table-async/DSDataTable.smoke.spec.js +4 -0
  50. package/ds-data-table-async/basic/DSDataTable.basic.axe-core.func.spec.js +1 -1
  51. package/ds-data-table-async/basic/DSDataTable.usecases.func.spec.js +5 -4
  52. package/ds-data-table-async/basic/DSDataTable.usecases.visual.spec.js +1 -0
  53. package/ds-data-table-async/components/HeaderCO.js +1 -1
  54. package/ds-data-table-async/components/RowCO.js +4 -0
  55. package/ds-data-table-async/dnd/DSDataTable.dnd.visual.spec.js +1 -1
  56. package/ds-data-table-async/filters/DSDataTable.filters-creatable.func.spec.js +4 -0
  57. package/ds-data-table-async/filters/DSDataTable.text-filters.func.spec.js +1 -0
  58. package/ds-data-table-async/select/DSDataTable.select.axe-core.func.spec.js +2 -0
  59. package/ds-data-table-async/select/DSDataTable.select.func.spec.js +2 -86
  60. package/ds-data-table-async/select/DSDataTable.select.shift.func.spec.js +126 -0
  61. package/ds-data-table-async/vissibility/DSDataTable.vissibility.visual.spec.js +6 -0
  62. package/ds-dialog/DSDialog.func.spec.js +14 -14
  63. package/ds-dialog/DSDialogCO.js +1 -1
  64. package/ds-dropdownmenu-v2/DSDDMenuV2.axe-core.func.spec.js +2 -0
  65. package/ds-dropdownmenu-v2/DSDDMenuV2CO.js +6 -2
  66. package/ds-form-combobox-multi/DSComboboxMultiCO.js +2 -9
  67. package/ds-form-combobox-multi/aria-disabled/DSComboboxMulti.aria-disabled.visual.spec.js +2 -11
  68. package/ds-form-combobox-multi/read-only/DSComboboxMulti.read-only.axe-core.func.spec.js +26 -0
  69. package/ds-form-combobox-multi/read-only/DSComboboxMulti.read-only.keyboard-nav.func.spec.js +27 -0
  70. package/ds-form-combobox-multi/read-only/DSComboboxMulti.read-only.visual.spec.js +33 -0
  71. package/ds-form-combobox-single/DSComboboxSingleCO.js +2 -9
  72. package/ds-form-combobox-single/read-only/DSComboboxSingle.read-only.axe-core.func.spec.js +26 -0
  73. package/ds-form-combobox-single/read-only/DSComboboxSingle.read-only.keyboard-nav.func.spec.js +27 -0
  74. package/ds-form-combobox-single/read-only/DSComboboxSingle.read-only.visual.spec.js +33 -0
  75. package/ds-form-layout-blocks/form-layout-block-item/DSFormLayoutBlockItemCO.js +9 -5
  76. package/ds-form-layout-blocks/form-layout-checkbox-group/DSFormLayoutCheckboxGroup.visual.spec.js +1 -1
  77. package/ds-form-layout-blocks/form-layout-checkbox-group/DSFormLayoutCheckboxGroupCO.js +2 -2
  78. package/ds-menu-button/DSMenuButtonCO.js +16 -12
  79. package/ds-menu-button/activable/DSMenuButton.activableMenuItem.func.spec.js +32 -0
  80. package/ds-menu-button/{basic/DSMenuButton.activableMenuItem.func.spec.js → activable/DSMenuButton.activableMenuItem.keyboardnav.func.spec.js} +1 -26
  81. package/ds-menu-button/disabled/DSMenuButton.axe-core.disabled.func.spec.js +20 -0
  82. package/ds-menu-button/disabled/DSMenuButton.disabled.func.spec.js +28 -0
  83. package/ds-menu-button/leftdecorations/DSMenuButton.axe-core.leftDecor.func.spec.js +20 -0
  84. package/ds-menu-button/multiselect/DSMenuButton.axe-core.multiselect.func.spec.js +28 -0
  85. package/ds-menu-button/multiselect/DSMenuButton.multiSelectItem.func.spec.js +34 -0
  86. package/ds-menu-button/{basic/DSMenuButton.multiSelectItem.func.spec.js → multiselect/DSMenuButton.multiSelectItem.keyboardnav.func.spec.js} +0 -29
  87. package/ds-menu-button/singleSelect/DSMenuButton.axe-core.singleSelect.func.spec.js +28 -0
  88. package/ds-menu-button/singleSelect/DSMenuButton.singleSelectItem.func.spec.js +39 -0
  89. package/ds-menu-button/{basic/DSMenuButton.singleSelectItem.func.spec.js → singleSelect/DSMenuButton.singleSelectItem.keyboardnav.func.spec.js} +11 -42
  90. package/ds-menu-button/submenu/DSMenuButton.axe-core.subMenu.func.spec.js +20 -0
  91. package/ds-menu-button/submenu/DSMenuButton.subMenuItem.func.spec.js +42 -0
  92. package/ds-menu-button/{basic/DSMenuButton.subMenuItem.func.spec.js → submenu/DSMenuButton.subMenuItem.keyboardnav.func.spec.js} +1 -38
  93. package/ds-mobile/MobileLoadingPage/MobileLoadingPageCO.js +1 -1
  94. package/ds-notification-badge/DSNotificationBadge.axe-core.func.spec.js +1 -0
  95. package/ds-pills-v2/DSPills.axe-core.func.spec.js +2 -2
  96. package/ds-pills-v2/DSPills.func.spec.js +26 -0
  97. package/ds-pills-v2/DSPills.visual.spec.js +1 -1
  98. package/ds-pills-v2/DSPillsV2CO.js +19 -1
  99. package/ds-pills-v2/selection/DSPills.axe-core.func.spec.js +77 -0
  100. package/ds-pills-v2/selection/DSPills.func.spec.js +155 -0
  101. package/ds-pills-v2/selection/DSPills.visual.spec.js +72 -0
  102. package/ds-query-builder/DSQueryBuilder.visual.spec.js +2 -1
  103. package/ds-query-builder/DSQueryBuilderCO.js +0 -5
  104. package/ds-shuttle-v2/DSShuttleV2CO.js +2 -4
  105. package/ds-shuttle-v2/Dnd/DSShuttleV2.DnD.visual.spec.js +0 -5
  106. package/ds-shuttle-v2/basic/DSShuttleV2.keyboard.func.spec.js +46 -66
  107. package/ds-shuttle-v2/drillingdown/DSShuttleV2.drilldown.kb.func.spec.js +3 -5
  108. package/ds-shuttle-v2/filtering/DSShuttleV2.filter.kb.func.spec.js +1 -7
  109. package/ds-shuttle-v2/globalcheckbox/DSShuttleV2.globalcheckbox.kb.func.spec.js +0 -2
  110. package/ds-shuttle-v2/items/DSShuttleV2.items.kb.func.spec.js +0 -2
  111. package/ds-slider-v2/DSSliderV2CO.js +10 -10
  112. package/ds-toast/DSToastCO.js +1 -1
  113. package/ds-toggle/DSToggle.func.spec.js +21 -18
  114. package/ds-toggle/DSToggle.visual.spec.js +56 -12
  115. package/package.json +119 -119
  116. package/ds-controlled-form/ds-controlled-date-range-picker/DSControlledDateRangePicker.DateInput.visual.spec.js +0 -57
  117. package/ds-menu-button/DSMenuButton.axe-core.func.spec.js +0 -66
  118. /package/ds-controlled-form/ds-controlled-date-time-picker/{date-time-picker → date-time-full}/DateTimePicker.custom.attributes.spec.js +0 -0
  119. /package/ds-controlled-form/ds-controlled-date-time-picker/{date-time-picker → date-time-full}/DateTimePicker.func.spec.js +0 -0
@@ -25,11 +25,11 @@ export default class DSCommentsCO extends PageObject {
25
25
  }
26
26
 
27
27
  static async getCardByIndex(index = 0) {
28
- return $$('[data-testid="ds-comment-card-root"]')[index];
28
+ return $$('[data-testid="ds-commentcard-root"]')[index];
29
29
  }
30
30
 
31
31
  static async getCardFocuseableByIndex(index = 0) {
32
- return $$('[data-testid="ds-comment-card-left"]')[index];
32
+ return $$('[data-testid="ds-commentcard-left"]')[index];
33
33
  }
34
34
 
35
35
  static getTriggerBtn() {
@@ -37,6 +37,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
37
37
  await browser.keys(Key.Tab);
38
38
  await browser.keys(Key.Enter);
39
39
  await browser.keys(Key.ArrowDown);
40
+ await browser.keys(Key.ArrowDown);
40
41
  await browser.keys(Key.Tab);
41
42
  const selectedOption = await DSComboboxCO.getSelectedValues();
42
43
  await expect(combobox).not.toBeFocused();
@@ -171,62 +171,7 @@ if (
171
171
  await expect(dropdownMenu).toBeDisplayed();
172
172
  });
173
173
  });
174
- describe('PUI-8166 - ComboboxV3:: Multi Select - selectAll - func', () => {
175
- before('loading page', async () => {
176
- const errorOnGo = await DSComboboxCO.multiSelectFixedWidth.go();
177
- if (errorOnGo) throw errorOnGo;
178
- });
179
- it('01: select all options', async () => {
180
- await DSComboboxCO.openMenuListMouse();
181
- const selectAllCheckbox = await DSComboboxCO.getSelectAllCheckbox();
182
- await selectAllCheckbox.click();
183
- const selectedOption = await DSComboboxCO.getOptionByLabel('Luke Skywalker too long this text is super long 1');
184
- const overflowPill = await DSComboboxCO.getPillByLabel('+8');
185
- const menulist = await DSComboboxCO.getMenuList();
186
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
187
- await expect(showSelectedBtn).toHaveTextContaining('SHOW SELECTED [9]');
188
- await expect(overflowPill).toBeDisplayedInViewport();
189
- await expect(menulist).toBeDisplayedInViewport();
190
- await expect(selectedOption).toBeDisplayedInViewport();
191
- });
192
- it('02: should display only selected options', async () => {
193
- const selectedOptionBtn = await DSComboboxCO.getSelectedOptionsToggle();
194
- await selectedOptionBtn.click();
195
- const numOptions = await DSComboboxCO.getNumberOptions();
196
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
197
- await expect(showSelectedBtn).toHaveTextContaining('SHOW ALL');
198
- await expect(numOptions).toBe(9);
199
- });
200
- it('03: should display all options', async () => {
201
- const showAllBtn = await DSComboboxCO.getSelectedOptionsToggle();
202
- await showAllBtn.click();
203
- const numOptions = await DSComboboxCO.getNumberOptions();
204
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
205
- await expect(showSelectedBtn).toHaveTextContaining('SHOW SELECTED [9]');
206
- await expect(numOptions).toBe(11);
207
- });
208
- it('04: should unselect last item', async () => {
209
- await browser.keys(Key.ArrowUp);
210
- const option2 = await DSComboboxCO.getOptionByIndex(9);
211
- await option2.click();
212
- const overflowPill = await DSComboboxCO.getPillByLabel('+7');
213
- await expect(overflowPill).toBeDisplayedInViewport();
214
- });
215
- it('05: should unselect all items', async () => {
216
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
217
- await showSelectedBtn.click();
218
- const selectAllCheckbox = await DSComboboxCO.getSelectAllCheckbox();
219
- await selectAllCheckbox.click();
220
- const numOptions = await DSComboboxCO.getNumberOptions();
221
- const zeroSelected = await DSComboboxCO.getZeroSelectedMsg();
222
- const selectedOption = await DSComboboxCO.getPillByLabel('Luke Skywalker too long this text is super long 1');
223
- const overflowPill = await DSComboboxCO.getPillByLabel('+7');
224
- await expect(zeroSelected).toBeDisplayedInViewport();
225
- await expect(numOptions).toBe(11);
226
- await expect(selectedOption).not.toBeDisplayedInViewport();
227
- await expect(overflowPill).not.toBeDisplayedInViewport();
228
- });
229
- });
174
+
230
175
  describe('PUI-8130 - ComboboxV3:: Single Select - basic- keyboard func', () => {
231
176
  before('loading page', async () => {
232
177
  const errorOnGo = await DSComboboxCO.singleSelectFixedWidth.go();
@@ -256,6 +201,7 @@ if (
256
201
  });
257
202
  it('05: should select an option and close the menu - ENTER', async () => {
258
203
  const menulist = await DSComboboxCO.getMenuList();
204
+ await browser.keys(Key.ArrowDown);
259
205
  await browser.keys(Key.Enter);
260
206
  const selectedOption = await DSComboboxCO.getSelectedValues();
261
207
  await expect(menulist).not.toBeDisplayed();
@@ -281,6 +227,7 @@ if (
281
227
  await browser.keys(Key.ArrowDown);
282
228
  await browser.keys(Key.ArrowDown);
283
229
  await browser.keys(Key.ArrowDown);
230
+ await browser.keys(Key.ArrowDown);
284
231
  await browser.keys(Key.Enter);
285
232
  const selectedOption = await DSComboboxCO.getSelectedValues();
286
233
  await expect(selectedOption).toHaveTextContaining('(555) 555-5555');
@@ -313,6 +260,7 @@ if (
313
260
  await expect(numOptions).toBe(2);
314
261
  });
315
262
  it('04: select filtered option - Enter', async () => {
263
+ await browser.keys(Key.ArrowDown);
316
264
  await browser.keys(Key.Enter);
317
265
  const selectedOption = await (await DSComboboxCO.getSimpleTruncateText()).getText();
318
266
  await expect(selectedOption).toBe('Luke Skywalker too long this text is super long');
@@ -82,15 +82,6 @@ export default class DSComboboxCO extends PageObject {
82
82
  return $('[data-testid="combobox-ally-selected-values"]');
83
83
  }
84
84
 
85
- // MENU
86
- static async getSelectAllCheckbox() {
87
- return $('#select-all-checkbox');
88
- }
89
-
90
- static async getSelectedOptionsToggle() {
91
- return $('[data-testid="combobox-selected-options-toggle"]');
92
- }
93
-
94
85
  static async getMenuList() {
95
86
  return $('[data-testid="combobox-menu-list"]');
96
87
  }
@@ -15,6 +15,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
15
15
  'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.';
16
16
  await browser.keys(Key.Tab);
17
17
  await type(longText);
18
+ await browser.keys(Key.ArrowDown);
18
19
  await browser.keys(Key.Enter);
19
20
  const pill = await DSComboboxCO.getPillByLabel(longText);
20
21
  const option = await DSComboboxCO.getOptionByLabel(longText);
@@ -24,6 +25,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
24
25
  it('02: create another option', async () => {
25
26
  const newOption = 'Lorem ipsum dolor sit amet';
26
27
  await type(newOption);
28
+ await browser.keys(Key.ArrowDown);
27
29
  await browser.keys(Key.Enter);
28
30
  const pill = await DSComboboxCO.getPillByLabel('+1');
29
31
  const option = await DSComboboxCO.getOptionByLabel(newOption);
@@ -35,6 +37,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
35
37
  'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.';
36
38
  const checkbox = await DSComboboxCO.getCheckboxByLabel(longText);
37
39
  await browser.keys(Key.ArrowDown);
40
+ await browser.keys(Key.ArrowDown);
38
41
  await browser.keys(Key.Enter);
39
42
  const pill = await DSComboboxCO.getPillByLabel(longText);
40
43
  const isChecked = await DSComboboxCO.isChecked(checkbox);
@@ -16,7 +16,6 @@ if (
16
16
  if (errorOnGo) throw errorOnGo;
17
17
  });
18
18
  it('should have a INLINE combobox integrated with dropdownPill and be axecore compliant', async () => {
19
- await browser.eyesOpen();
20
19
  const dropDownPillBtn = await DSComboboxCO.getPillDropDownBtn();
21
20
  await dropDownPillBtn.click();
22
21
  const option1 = await DSComboboxCO.getOptionByIndex(0);
@@ -28,6 +28,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
28
28
  it('03: should open the dropdown menu and select an option - SPACE-ENTER', async () => {
29
29
  await browser.keys(Key.Enter);
30
30
  await browser.keys(Key.ArrowDown);
31
+ await browser.keys(Key.ArrowDown);
31
32
  await browser.keys(Key.Enter);
32
33
  const pill = await DSComboboxCO.getPillByLabel('Obi-Wan Kenobi');
33
34
  const checkbox = await DSComboboxCO.getCheckboxByIndex(1);
@@ -39,6 +40,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
39
40
  await browser.keys(Key.ArrowUp);
40
41
  await browser.keys(Key.ArrowUp);
41
42
  await browser.keys(Key.ArrowUp);
43
+ await browser.keys(Key.ArrowUp);
42
44
  await browser.keys(Key.Enter);
43
45
  const pill = await DSComboboxCO.getPillByLabel('Padme Amidala');
44
46
  const checkbox = await DSComboboxCO.getCheckboxByIndex(2);
@@ -70,6 +72,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
70
72
  await expect(numOptions).toBe(2);
71
73
  });
72
74
  it('02: should select a filtered option - Enter', async () => {
75
+ await browser.keys(Key.ArrowDown);
73
76
  await browser.keys(Key.ArrowDown);
74
77
  await browser.keys(Key.Enter);
75
78
  const pill = await DSComboboxCO.getPillByLabel('Anakin Skywalker');
@@ -88,6 +91,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
88
91
  await expect(numOptions).toBe(1);
89
92
  });
90
93
  it('05: select an option - ENTER', async () => {
94
+ await browser.keys(Key.ArrowDown);
91
95
  await browser.keys(Key.Enter);
92
96
  const pill = await DSComboboxCO.getPillByLabel('Luke Skywalker too long this text is super long');
93
97
  const checkbox = await DSComboboxCO.getCheckboxByIndex(0);
@@ -99,6 +103,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
99
103
  await browser.keys(Key.ArrowDown);
100
104
  await browser.keys(Key.ArrowDown);
101
105
  await browser.keys(Key.ArrowDown);
106
+ await browser.keys(Key.ArrowDown);
102
107
  await browser.keys(Key.Enter);
103
108
  const pill = await DSComboboxCO.getPillByLabel('Anakin Skywalker');
104
109
  const checkbox = await DSComboboxCO.getCheckboxByLabel('Anakin Skywalker');
@@ -33,6 +33,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
33
33
  });
34
34
  it('05: should select an option and not close the menu - ENTER', async () => {
35
35
  const menulist = await DSComboboxCO.getMenuList();
36
+ await browser.keys(Key.ArrowDown);
36
37
  await browser.keys(Key.Enter);
37
38
  const selectedOption = await DSComboboxCO.getSelectedValues();
38
39
  await expect(menulist).toBeDisplayed();
@@ -41,6 +42,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
41
42
  it('06: should select last option and not close the menu - ArrowUp', async () => {
42
43
  const menulist = await DSComboboxCO.getMenuList();
43
44
  await browser.keys(Key.ArrowUp);
45
+ await browser.keys(Key.ArrowUp);
44
46
  await browser.keys(Key.Enter);
45
47
  const overflowPill = await DSComboboxCO.getPillByLabel('+1');
46
48
  await expect(menulist).toBeDisplayed();
@@ -55,6 +57,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
55
57
  await browser.keys(Key.ArrowDown);
56
58
  await browser.keys(Key.ArrowDown);
57
59
  await browser.keys(Key.ArrowDown);
60
+ await browser.keys(Key.ArrowDown);
58
61
  await browser.keys(Key.Enter);
59
62
  const selectedOption = await DSComboboxCO.getPillByLabel('+1');
60
63
  await expect(selectedOption).toBeDisplayedInViewport();
@@ -68,6 +71,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
68
71
  it('01: should unselect an option - Backspace', async () => {
69
72
  await browser.keys(Key.Tab);
70
73
  await type(')');
74
+ await browser.keys(Key.ArrowDown);
71
75
  await browser.keys(Key.Enter);
72
76
  const selectedOption = await DSComboboxCO.getPillByLabel('(555) 555-5555');
73
77
  await selectedOption.waitForDisplayed();
@@ -76,6 +80,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
76
80
  });
77
81
  it('02: should unselect an option - using X close pill btn', async () => {
78
82
  await type('2');
83
+ await browser.keys(Key.ArrowDown);
79
84
  await browser.keys(Key.Enter);
80
85
  const selectedOption = await DSComboboxCO.getPillByLabel('Luke Skywalker too long this text is super long 2');
81
86
  await selectedOption.waitForDisplayed();
@@ -111,6 +116,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
111
116
  await expect(numOptions).toBe(3);
112
117
  });
113
118
  it('04: select filtered option - Enter', async () => {
119
+ await browser.keys(Key.ArrowDown);
114
120
  await browser.keys(Key.Enter);
115
121
  const selectedOption = await DSComboboxCO.getPillByLabel('Luke Skywalker too long this text is super long 1');
116
122
  await expect(selectedOption).toBeDisplayed();
@@ -144,72 +150,4 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
144
150
  await expect(inputText).toBeFocused();
145
151
  });
146
152
  });
147
- describe('PUI-8139 - ComboboxV3:: Multi Select - selectAll - keyboard func', () => {
148
- before('loading page', async () => {
149
- const errorOnGo = await DSComboboxCO.multiSelectFixedWidth.go();
150
- if (errorOnGo) throw errorOnGo;
151
- });
152
- it('01: select all options', async () => {
153
- await DSComboboxCO.openMenuUsingKeyboard();
154
- await browser.keys(Key.Tab);
155
- await browser.keys(Key.Space);
156
- const selectedOption = await DSComboboxCO.getOptionByLabel('Luke Skywalker too long this text is super long 1');
157
- const overflowPill = await DSComboboxCO.getPillByLabel('+8');
158
- const menulist = await DSComboboxCO.getMenuList();
159
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
160
- await expect(showSelectedBtn).toHaveTextContaining('SHOW SELECTED [9]');
161
- await expect(overflowPill).toBeDisplayedInViewport();
162
- await expect(menulist).toBeDisplayedInViewport();
163
- await expect(selectedOption).toBeDisplayedInViewport();
164
- });
165
- it('02: should display only selected options', async () => {
166
- await browser.keys(Key.Tab);
167
- await browser.keys(Key.Space);
168
- const numOptions = await DSComboboxCO.getNumberOptions();
169
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
170
- await expect(showSelectedBtn).toHaveTextContaining('SHOW ALL');
171
- await expect(numOptions).toBe(9);
172
- });
173
- it('03: should unselect last item', async () => {
174
- await browser.keys(Key.Tab);
175
- await browser.keys(Key.Enter);
176
- const option = await DSComboboxCO.getOptionByLabel('Anakin Skywalker 5');
177
- const overflowPill = await DSComboboxCO.getPillByLabel('+7');
178
- await expect(option).not.toBeDisplayedInViewport();
179
- await expect(overflowPill).toBeDisplayedInViewport();
180
- });
181
- it('04: should unselect all items', async () => {
182
- await browser.keys(Key.Tab);
183
- await browser.keys(Key.Space);
184
- const numOptions = await DSComboboxCO.getNumberOptions();
185
- const zeroSelected = await DSComboboxCO.getZeroSelectedMsg();
186
- const selectedOption = await DSComboboxCO.getPillByLabel('Luke Skywalker too long this text is super long 1');
187
- const overflowPill = await DSComboboxCO.getPillByLabel('+8');
188
- await expect(zeroSelected).toBeDisplayedInViewport();
189
- await expect(numOptions).toBe(11);
190
- await expect(selectedOption).not.toBeDisplayedInViewport();
191
- await expect(overflowPill).not.toBeDisplayedInViewport();
192
- });
193
- it('05: should close menu list correctly - focus in selectAll checkbox', async () => {
194
- await browser.keys(Key.Tab);
195
- await browser.keys(Key.Escape);
196
- const menulist = await DSComboboxCO.getMenuList();
197
- const comboboxInput = await DSComboboxCO.getComboboxInput();
198
- await expect(menulist).not.toBeDisplayedInViewport();
199
- await expect(comboboxInput).toBeFocused();
200
- });
201
- it('06: should close menu list correctly - focus in show selected toggle btn', async () => {
202
- await browser.keys(Key.Enter);
203
- await browser.keys(Key.Tab);
204
- await browser.keys(Key.Space);
205
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
206
- await showSelectedBtn.waitForDisplayed();
207
- await browser.keys(Key.Tab);
208
- await browser.keys(Key.Escape);
209
- const menulist = await DSComboboxCO.getMenuList();
210
- const comboboxInput = await DSComboboxCO.getComboboxInput();
211
- await expect(menulist).not.toBeDisplayedInViewport();
212
- await expect(comboboxInput).toBeFocused();
213
- });
214
- });
215
153
  }
@@ -162,62 +162,4 @@ if (!browser.capabilities['ice:options'].isPhone && browser.capabilities.browser
162
162
  });
163
163
  });
164
164
  }
165
- describe('PUI-8166 - ComboboxV3:: Multi Select - selectAll - func', () => {
166
- before('loading page', async () => {
167
- const errorOnGo = await DSComboboxCO.multiSelectFixedWidth.go();
168
- if (errorOnGo) throw errorOnGo;
169
- });
170
- it('01: select all options', async () => {
171
- await DSComboboxCO.openMenuListMouse();
172
- const selectAllCheckbox = await DSComboboxCO.getSelectAllCheckbox();
173
- await selectAllCheckbox.click();
174
- const selectedOption = await DSComboboxCO.getOptionByLabel('Luke Skywalker too long this text is super long 1');
175
- const overflowPill = await DSComboboxCO.getPillByLabel('+8');
176
- const menulist = await DSComboboxCO.getMenuList();
177
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
178
- await expect(showSelectedBtn).toHaveTextContaining('SHOW SELECTED [9]');
179
- await expect(overflowPill).toBeDisplayedInViewport();
180
- await expect(menulist).toBeDisplayedInViewport();
181
- await expect(selectedOption).toBeDisplayedInViewport();
182
- });
183
- it('02: should display only selected options', async () => {
184
- const selectedOptionBtn = await DSComboboxCO.getSelectedOptionsToggle();
185
- await selectedOptionBtn.click();
186
- const numOptions = await DSComboboxCO.getNumberOptions();
187
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
188
- await expect(showSelectedBtn).toHaveTextContaining('SHOW ALL');
189
- await expect(numOptions).toBe(9);
190
- });
191
- it('03: should display all options', async () => {
192
- const showAllBtn = await DSComboboxCO.getSelectedOptionsToggle();
193
- await showAllBtn.click();
194
- const numOptions = await DSComboboxCO.getNumberOptions();
195
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
196
- await expect(showSelectedBtn).toHaveTextContaining('SHOW SELECTED [9]');
197
- await expect(numOptions).toBe(11);
198
- });
199
- it('04: should unselect last item', async () => {
200
- const option = await DSComboboxCO.getOptionByLabel('Padme Amidala 3');
201
- await option.scrollIntoView();
202
- const option2 = await DSComboboxCO.getOptionByLabel('Anakin Skywalker 5');
203
- await option2.scrollIntoView();
204
- await option2.click();
205
- const overflowPill = await DSComboboxCO.getPillByLabel('+7');
206
- await expect(overflowPill).toBeDisplayedInViewport();
207
- });
208
- it('05: should unselect all items', async () => {
209
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
210
- await showSelectedBtn.click();
211
- const selectAllCheckbox = await DSComboboxCO.getSelectAllCheckbox();
212
- await selectAllCheckbox.click();
213
- const numOptions = await DSComboboxCO.getNumberOptions();
214
- const zeroSelected = await DSComboboxCO.getZeroSelectedMsg();
215
- const selectedOption = await DSComboboxCO.getPillByLabel('Luke Skywalker too long this text is super long 1');
216
- const overflowPill = await DSComboboxCO.getPillByLabel('+7');
217
- await expect(zeroSelected).toBeDisplayedInViewport();
218
- await expect(numOptions).toBe(11);
219
- await expect(selectedOption).not.toBeDisplayedInViewport();
220
- await expect(overflowPill).not.toBeDisplayedInViewport();
221
- });
222
- });
223
165
  }
@@ -43,22 +43,6 @@ if (!browser.capabilities['ice:options'].isPhone && browser.capabilities.browser
43
43
  );
44
44
  await expect(snapshot).toEqual(0);
45
45
  });
46
- it('05: should display only selected options - click show selected', async () => {
47
- await browser.eyesOpen();
48
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
49
- await showSelectedBtn.click();
50
- const snapshot = await browser.eyesCheckSnapshot(DSComboboxCO.snapshotPath('comboboxV3-multi-show-selected'));
51
- await expect(snapshot).toEqual(0);
52
- });
53
- it('06: should display all options - click select all', async () => {
54
- await browser.eyesOpen();
55
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
56
- await showSelectedBtn.click();
57
- const selectAll = await DSComboboxCO.getSelectAllCheckbox();
58
- await selectAll.click();
59
- const snapshot = await browser.eyesCheckSnapshot(DSComboboxCO.snapshotPath('comboboxV3-multi-all-selected'));
60
- await expect(snapshot).toEqual(0);
61
- });
62
46
  if (browser.capabilities['ice:options'].isTablet) {
63
47
  it('07: should display tooltip - touch truncated pill', async () => {
64
48
  await browser.eyesOpen();
@@ -121,6 +105,7 @@ if (!browser.capabilities['ice:options'].isPhone && browser.capabilities.browser
121
105
  await browser.keys(Key.ArrowUp);
122
106
  await browser.keys(Key.ArrowUp);
123
107
  await browser.keys(Key.ArrowUp);
108
+ await browser.keys(Key.ArrowUp);
124
109
  await browser.keys(Key.Enter);
125
110
  const snapshot = await browser.eyesCheckSnapshot(
126
111
  DSComboboxCO.snapshotPath('comboboxV3-multi-scroll-up-keyboard'),
@@ -10,12 +10,9 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
10
10
  });
11
11
  it('01: should select all the options correctly', async () => {
12
12
  await DSComboboxCO.openMenuListMouse();
13
- const selectAllCheckbox = await DSComboboxCO.getSelectAllCheckbox();
14
- await selectAllCheckbox.click();
15
- const selectedOption = await DSComboboxCO.getOptionByLabel('Option 9999');
13
+ await browser.keys(['Control', 'a']);
14
+ const selectedOption = await DSComboboxCO.getOptionByLabel('Option 0');
16
15
  const overflowPill = await DSComboboxCO.getPillByLabel('+9999');
17
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
18
- await expect(showSelectedBtn).toHaveTextContaining('SHOW SELECTED [10000]');
19
16
  await expect(overflowPill).toBeDisplayedInViewport();
20
17
  await expect(selectedOption).toBeDisplayedInViewport();
21
18
  });
@@ -26,22 +23,5 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
26
23
  const overflowPill = await DSComboboxCO.getPillByLabel('+9998');
27
24
  await expect(overflowPill).toBeDisplayedInViewport();
28
25
  });
29
- it('03: should display selected options', async () => {
30
- const option7 = await DSComboboxCO.getOptionByLabel('Option 7');
31
- const selectedOptionBtn = await DSComboboxCO.getSelectedOptionsToggle();
32
- await selectedOptionBtn.click();
33
- const showSelectedBtn = await DSComboboxCO.getSelectedOptionsToggle();
34
- await showSelectedBtn.waitForDisplayed();
35
- await expect(showSelectedBtn).toHaveTextContaining('SHOW ALL');
36
- await expect(option7).not.toBeDisplayedInViewport();
37
- });
38
- it('04: should unselect all options', async () => {
39
- const overflowPill = await DSComboboxCO.getPillByLabel('+9998');
40
- const selectedOption = await DSComboboxCO.getPillByLabel('Option 0');
41
- const selectAllCheckbox = await DSComboboxCO.getSelectAllCheckbox();
42
- await selectAllCheckbox.click();
43
- await expect(overflowPill).not.toBeDisplayedInViewport();
44
- await expect(selectedOption).not.toBeDisplayedInViewport();
45
- });
46
26
  });
47
27
  }
@@ -34,6 +34,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
34
34
  });
35
35
  it('05: should select an option and close the menu - ENTER', async () => {
36
36
  const menulist = await DSComboboxCO.getMenuList();
37
+ await browser.keys(Key.ArrowDown);
37
38
  await browser.keys(Key.Enter);
38
39
  const selectedOption = await DSComboboxCO.getSelectedValues();
39
40
  await expect(menulist).not.toBeDisplayed();
@@ -59,6 +60,8 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
59
60
  await browser.keys(Key.ArrowDown);
60
61
  await browser.keys(Key.ArrowDown);
61
62
  await browser.keys(Key.ArrowDown);
63
+ await browser.keys(Key.ArrowDown);
64
+ await browser.keys(Key.ArrowDown);
62
65
  await browser.keys(Key.Enter);
63
66
  const selectedOption = await DSComboboxCO.getSelectedValues();
64
67
  await expect(selectedOption).toHaveTextContaining('(555) 555-5555');
@@ -91,6 +94,7 @@ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:o
91
94
  await expect(numOptions).toBe(2);
92
95
  });
93
96
  it('04: select filtered option - Enter', async () => {
97
+ await browser.keys(Key.ArrowDown);
94
98
  await browser.keys(Key.Enter);
95
99
  const selectedOption = await (await DSComboboxCO.getSimpleTruncateText()).getText();
96
100
  await expect(selectedOption).toBe('Luke Skywalker too long this text is super long');
@@ -0,0 +1,85 @@
1
+ import DSControlledDateRangePickerCO from './DSControlledDateRangePickerCO';
2
+ import { axeCoreCheck, type } from '../../helpers';
3
+ import { Key } from 'webdriverio';
4
+
5
+ if (!browser.capabilities['ice:options'].isPhone && !browser.capabilities['ice:options'].isTablet) {
6
+ describe('PUI-14853 - DSControlledDateRangePicker:: Basic -AxeCore', () => {
7
+ before('loading page', async () => {
8
+ const errorOnGo = await DSControlledDateRangePickerCO.basic.go();
9
+ if (errorOnGo) throw errorOnGo;
10
+ });
11
+ it('01: should have closed calendar, empty input and pass axe-core scan', async () => {
12
+ const calendarTrigger = await DSControlledDateRangePickerCO.getPickerBtn();
13
+ await calendarTrigger.waitForDisplayed();
14
+ const result = await axeCoreCheck();
15
+ expect(result.length).toBe(0);
16
+ });
17
+ it('02: should have expanded calendar, empty input and pass axe-core scan', async () => {
18
+ const calendarTrigger = await DSControlledDateRangePickerCO.getPickerBtn();
19
+ await calendarTrigger.click();
20
+ const result = await axeCoreCheck();
21
+ expect(result.length).toBe(0);
22
+ });
23
+ it('03: should have expanded calendar, populated input and pass axe-core scan', async () => {
24
+ const beginDate = await DSControlledDateRangePickerCO.getDayOnCalendarByIndex(10);
25
+ await beginDate.click();
26
+ const endDate = await DSControlledDateRangePickerCO.getDayOnCalendarByIndex(16);
27
+ await endDate.click();
28
+ const result = await axeCoreCheck();
29
+ expect(result.length).toBe(0);
30
+ });
31
+ it('04: should have expanded calendar, populated input and pass axe-core scan', async () => {
32
+ await browser.keys(Key.Escape);
33
+ const result = await axeCoreCheck();
34
+ expect(result.length).toBe(0);
35
+ });
36
+ });
37
+
38
+ describe('PUI-14855 - DSControlledDateRangePicker:: Invalid selection -AxeCore', () => {
39
+ before('loading page', async () => {
40
+ const errorOnGo = await DSControlledDateRangePickerCO.invalidSelection.go();
41
+ if (errorOnGo) throw errorOnGo;
42
+ });
43
+ it('01: should have invalid date range picker with closed calendar and pass axe-core scan', async () => {
44
+ const calendarTrigger = await DSControlledDateRangePickerCO.getPickerBtn();
45
+ await calendarTrigger.waitForDisplayed();
46
+ const result = await axeCoreCheck();
47
+ expect(result.length).toBe(0);
48
+ });
49
+ it('02: should have invalid date range picker with expanded calendar and pass axe-core scan', async () => {
50
+ const calendarTrigger = await DSControlledDateRangePickerCO.getPickerBtn();
51
+ await calendarTrigger.click();
52
+ const result = await axeCoreCheck();
53
+ expect(result.length).toBe(0);
54
+ });
55
+ });
56
+
57
+ describe('PUI-14854 - DSControlledDateRangePicker:: Disabled -AxeCore', () => {
58
+ before('loading page', async () => {
59
+ const errorOnGo = await DSControlledDateRangePickerCO.disabled.go();
60
+ if (errorOnGo) throw errorOnGo;
61
+ });
62
+ it('01: should have disabled date range picker and pass axe-core scan', async () => {
63
+ const calendarTrigger = await DSControlledDateRangePickerCO.getPickerBtn();
64
+ await calendarTrigger.waitForDisplayed();
65
+ const result = await axeCoreCheck();
66
+ expect(result.length).toBe(0);
67
+ });
68
+ });
69
+
70
+ describe('PUI-14862 - DSControlledDateRangePicker:: Clearable -AxeCore', () => {
71
+ before('loading page', async () => {
72
+ const errorOnGo = await DSControlledDateRangePickerCO.clearable.go();
73
+ if (errorOnGo) throw errorOnGo;
74
+ });
75
+ it('01: should have two clearable inputs. One populated, one empty and pass axe-core scan', async () => {
76
+ const calendarTrigger = await DSControlledDateRangePickerCO.getPickerBtn();
77
+ await calendarTrigger.waitForDisplayed();
78
+ await browser.keys(Key.Tab);
79
+ await browser.keys(Key.Tab);
80
+ await type('02032020');
81
+ const result = await axeCoreCheck();
82
+ expect(result.length).toBe(0);
83
+ });
84
+ });
85
+ }