- fix DataTable.spec.js

pull/6170/head
uros 2024-08-01 22:50:25 +02:00
parent 6c6e627545
commit f8d1dfc8b2
1 changed files with 53 additions and 53 deletions
packages/primevue/src/datatable

View File

@ -118,14 +118,14 @@ describe('DataTable.vue', () => {
it('should exist', () => {
expect(wrapper.find('.p-datatable.p-component').exists()).toBe(true);
expect(wrapper.find('.p-datatable-wrapper').exists()).toBe(true);
expect(wrapper.find('.p-datatable-table-container').exists()).toBe(true);
expect(wrapper.find('table.p-datatable-table').exists()).toBe(true);
expect(wrapper.find('thead.p-datatable-thead').exists()).toBe(true);
expect(wrapper.find('tbody.p-datatable-tbody').exists()).toBe(true);
});
it('should have basic demo', () => {
expect(wrapper.findAll('.p-column-header-content').length).toEqual(3);
expect(wrapper.findAll('.p-datatable-column-header-content').length).toEqual(3);
const tbody = wrapper.find('.p-datatable-tbody');
expect(tbody.findAll('tr').length).toEqual(3);
@ -156,22 +156,22 @@ describe('DataTable.vue', () => {
it('should have empty templating', async () => {
await wrapper.setProps({ value: [] });
expect(wrapper.find('tr.p-datatable-emptymessage').exists()).toBe(true);
expect(wrapper.find('tr.p-datatable-emptymessage').text()).toBe('Empty Templating');
expect(wrapper.find('tr.p-datatable-empty-message').exists()).toBe(true);
expect(wrapper.find('tr.p-datatable-empty-message').text()).toBe('Empty Templating');
});
it('should have paginatorstart templating', async () => {
await wrapper.setProps({ value: data, paginator: true, rows: 5 });
expect(wrapper.find('.p-paginator-left-content').exists()).toBe(true);
expect(wrapper.find('.p-paginator-left-content').text()).toBe('Paginator Start Templating');
expect(wrapper.find('.p-paginator-content-start').exists()).toBe(true);
expect(wrapper.find('.p-paginator-content-start').text()).toBe('Paginator Start Templating');
});
it('should have paginatorend templating', async () => {
await wrapper.setProps({ value: data, paginator: true, rows: 5 });
expect(wrapper.find('.p-paginator-right-content').exists()).toBe(true);
expect(wrapper.find('.p-paginator-right-content').text()).toBe('Paginator End Templating');
expect(wrapper.find('.p-paginator-content-end').exists()).toBe(true);
expect(wrapper.find('.p-paginator-content-end').text()).toBe('Paginator End Templating');
});
// column templating
@ -251,8 +251,8 @@ describe('DataTable.vue', () => {
}
});
expect(wrapper.find('.p-datatable').classes()).toContain('p-datatable-grouped-header');
expect(wrapper.find('.p-datatable').classes()).toContain('p-datatable-grouped-footer');
expect(wrapper.find('.p-datatable .p-datatable-tfoot').exists()).toBe(true);
expect(wrapper.find('.p-datatable .p-datatable-thead').exists()).toBe(true);
const headerRows = wrapper.findAll('.p-datatable-thead > tr');
@ -302,14 +302,14 @@ describe('DataTable.vue', () => {
}
});
const sortableTH = wrapper.findAll('.p-sortable-column')[0];
const sortableTH = wrapper.findAll('.p-datatable-sortable-column')[0];
const firstCellText = wrapper.findAll('.p-datatable-tbody > tr')[0].findAll('td')[1].text();
const headerClick = vi.spyOn(wrapper.vm, 'onColumnHeaderClick');
await sortableTH.trigger('click');
expect(headerClick).toHaveBeenCalled();
expect(sortableTH.classes()).toContain('p-highlight');
expect(sortableTH.classes()).toContain('p-datatable-column-sorted');
expect(wrapper.findAll('.p-datatable-tbody > tr')[0].findAll('td')[1].text()).not.toEqual(firstCellText);
expect(wrapper.emitted()['update:sortField'][0]).toEqual(['code']);
expect(wrapper.emitted()['value-change'][0]).not.toBeNull();
@ -335,7 +335,7 @@ describe('DataTable.vue', () => {
}
});
const sortableTHs = wrapper.findAll('.p-sortable-column');
const sortableTHs = wrapper.findAll('.p-datatable-sortable-column');
const firstCellText = wrapper.findAll('.p-datatable-tbody > tr')[0].findAll('td')[1].text();
const headerClick = vi.spyOn(wrapper.vm, 'onColumnHeaderClick');
@ -349,7 +349,7 @@ describe('DataTable.vue', () => {
await sortableTHs[1].trigger('click');
expect(headerClick).toHaveBeenCalled();
expect(sortableTHs[1].classes()).toContain('p-highlight');
expect(sortableTHs[1].classes()).toContain('p-datatable-column-sorted');
expect(wrapper.emitted()['update:multiSortMeta'][0]).toEqual([[{ field: 'code', order: 1 }]]);
expect(wrapper.emitted()['update:multiSortMeta'][1]).toEqual([[{ field: 'name', order: 1 }]]);
expect(wrapper.emitted()['value-change'][0]).not.toEqual(wrapper.emitted()['value-change'][1]);
@ -377,10 +377,10 @@ describe('DataTable.vue', () => {
}
});
const presortedTH = wrapper.findAll('.p-sortable-column')[0];
const presortedTH = wrapper.findAll('.p-datatable-sortable-column')[0];
expect(wrapper.findAll('.p-datatable-tbody > tr')[0].findAll('td')[1].text()).not.toEqual('Game Controller');
expect(presortedTH.classes()).toContain('p-highlight');
expect(presortedTH.classes()).toContain('p-datatable-column-sorted');
});
it('should remove sort', async () => {
@ -403,7 +403,7 @@ describe('DataTable.vue', () => {
}
});
const sortableTH = wrapper.findAll('.p-sortable-column')[0];
const sortableTH = wrapper.findAll('.p-datatable-sortable-column')[0];
const firstCellText = wrapper.findAll('.p-datatable-tbody > tr')[0].findAll('td')[1].text();
await sortableTH.trigger('click');
@ -458,7 +458,7 @@ describe('DataTable.vue', () => {
await wrapper.setProps({ selection: null, selectionMode: 'single' });
await wrapper.vm.onRowClick({
originalEvent: { target: wrapper.findAll('tr.p-selectable-row')[0].element },
originalEvent: { target: wrapper.findAll('tr.p-datatable-selectable-row')[0].element },
data: smallData[0],
index: 0
});
@ -472,13 +472,13 @@ describe('DataTable.vue', () => {
await wrapper.setProps({ selection: null, selectionMode: 'multiple' });
await wrapper.vm.onRowClick({
originalEvent: { shiftKey: true, target: wrapper.findAll('tr.p-selectable-row')[0].element },
originalEvent: { shiftKey: true, target: wrapper.findAll('tr.p-datatable-selectable-row')[0].element },
data: smallData[0],
index: 0
});
await wrapper.vm.onRowClick({
originalEvent: { shiftKey: true, target: wrapper.findAll('tr.p-selectable-row')[1].element },
originalEvent: { shiftKey: true, target: wrapper.findAll('tr.p-datatable-selectable-row')[1].element },
data: smallData[1],
index: 1
});
@ -492,13 +492,13 @@ describe('DataTable.vue', () => {
await wrapper.setProps({ selection: null, selectionMode: 'multiple', metaKeySelection: false });
await wrapper.vm.onRowClick({
originalEvent: { target: wrapper.findAll('tr.p-selectable-row')[0].element },
originalEvent: { target: wrapper.findAll('.p-datatable-selectable-row')[0].element },
data: smallData[0],
index: 0
});
await wrapper.vm.onRowClick({
originalEvent: { target: wrapper.findAll('tr.p-selectable-row')[1].element },
originalEvent: { target: wrapper.findAll('tr.p-datatable-selectable-row')[1].element },
data: smallData[1],
index: 1
});
@ -533,7 +533,7 @@ describe('DataTable.vue', () => {
}
});
expect(wrapper.findAll('td.p-selection-column').length).toBe(3);
expect(wrapper.findAll('td[data-p-selection-column="true"]').length).toBe(3);
expect(wrapper.findAll('.p-radiobutton').length).toBe(3);
await wrapper.vm.toggleRowWithRadio({ originalEvent: {}, data: smallData[0], index: 0 });
@ -646,7 +646,7 @@ describe('DataTable.vue', () => {
it('should vertical scroll', async () => {
await wrapper.setProps({ scrollable: true, scrollHeight: '100px' });
expect(wrapper.find('.p-datatable-wrapper').attributes().style).toBe('overflow: auto; max-height: 100px;');
expect(wrapper.find('.p-datatable-table-container').attributes().style).toBe('overflow: auto; max-height: 100px;');
});
it('should flex scrolling', async () => {
@ -686,9 +686,9 @@ describe('DataTable.vue', () => {
}
});
expect(wrapper.find('th.p-frozen-column').exists()).toBe(true);
expect(wrapper.find('th.p-datatable-frozen-column').exists()).toBe(true);
// expect(wrapper.find('th.p-frozen-column').attributes().style).toBe('left: 0px;');
expect(wrapper.findAll('td.p-frozen-column').length).toBe(3);
expect(wrapper.findAll('td.p-datatable-frozen-column').length).toBe(3);
// expect(wrapper.findAll('td.p-frozen-column')[0].attributes().style).toBe('left: 0px;');
});
@ -696,7 +696,7 @@ describe('DataTable.vue', () => {
// row expansion
it('should have row toggler', () => {
expect(wrapper.findAll('.p-row-toggler').length).toBe(3);
expect(wrapper.findAll('.p-datatable-row-toggle-button').length).toBe(3);
});
it('should expand a row', async () => {
@ -752,14 +752,14 @@ describe('DataTable.vue', () => {
}
});
expect(wrapper.findAll('.p-editable-column').length).toBe(6);
expect(wrapper.findAll('.p-row-editor-init').length).toBe(3);
expect(wrapper.findAll('[data-p-editable-column="true"]').length).toBe(6);
expect(wrapper.findAll('.p-datatable-row-editor-init').length).toBe(3);
await wrapper.vm.onRowEditInit({ data: smallData[0] });
expect(wrapper.emitted()['update:editingRows'][0][0]).toEqual([smallData[0]]);
expect(wrapper.emitted()['row-edit-init'][0][0].data).toEqual(smallData[0]);
expect(wrapper.findAll('.p-datatable-tbody > tr > td')[wrapper.findAll('.p-datatable-tbody > tr > td').length - 1].find('.p-row-editor-init').exists()).toBe(true);
expect(wrapper.findAll('.p-datatable-tbody > tr > td')[wrapper.findAll('.p-datatable-tbody > tr > td').length - 1].find('.p-datatable-row-editor-init').exists()).toBe(true);
});
it('should save row editing', async () => {
@ -860,7 +860,7 @@ describe('DataTable.vue', () => {
expect(wrapper.find('.p-datatable.p-component').classes()).toContain('p-datatable-resizable');
expect(wrapper.find('.p-datatable.p-component').classes()).toContain('p-datatable-resizable-fit');
expect(wrapper.findAll('.p-column-resizer').length).toBe(2);
expect(wrapper.findAll('.p-datatable-column-resizer').length).toBe(2);
});
it('should fit mode resize start', async () => {
@ -884,12 +884,12 @@ describe('DataTable.vue', () => {
}
});
const resizer = wrapper.findAll('.p-column-resizer')[0];
const resizer = wrapper.findAll('.p-datatable-column-resizer')[0];
await wrapper.vm.onColumnResizeStart({ target: resizer.element });
expect(wrapper.componentVM.columnResizing).toBe(true);
expect(wrapper.find('.p-column-resizer-helper').attributes().style).toContain('display: none;');
expect(wrapper.find('.p-datatable-column-resize-indicator').attributes().style).toContain('display: none;');
});
it('should fit mode resize', async () => {
@ -915,7 +915,7 @@ describe('DataTable.vue', () => {
await wrapper.vm.onColumnResize({});
expect(wrapper.find('.p-column-resizer-helper').attributes().style).toContain('display: none; height: 0px; top: 0px;');
expect(wrapper.find('.p-datatable-column-resize-indicator').attributes().style).toContain('display: none; height: 0px; top: 0px;');
});
it('should fit mode column resize end', async () => {
@ -939,13 +939,13 @@ describe('DataTable.vue', () => {
}
});
const resizer = wrapper.findAll('.p-column-resizer')[0];
const resizer = wrapper.findAll('.p-datatable-column-resizer')[0];
await wrapper.vm.onColumnResizeStart({ target: resizer.element });
await wrapper.vm.onColumnResizeEnd();
expect(wrapper.find('.p-column-resizer-helper').attributes().style).toContain('display: none;');
expect(wrapper.find('.p-datatable-column-resize-indicator').attributes().style).toContain('display: none;');
});
it('should expand mode resize start', async () => {
@ -969,12 +969,12 @@ describe('DataTable.vue', () => {
}
});
const resizer = wrapper.findAll('.p-column-resizer')[0];
const resizer = wrapper.findAll('.p-datatable-column-resizer')[0];
await wrapper.vm.onColumnResizeStart({ target: resizer.element });
expect(wrapper.componentVM.columnResizing).toBe(true);
expect(wrapper.find('.p-column-resizer-helper').attributes().style).toContain('display: none;');
expect(wrapper.find('.p-datatable-column-resize-indicator').attributes().style).toContain('display: none;');
});
it('should fit mode resize', async () => {
@ -1000,7 +1000,7 @@ describe('DataTable.vue', () => {
await wrapper.vm.onColumnResize({});
expect(wrapper.find('.p-column-resizer-helper').attributes().style).toContain('display: none; height: 0px; top: 0px;');
expect(wrapper.find('.p-datatable-column-resize-indicator').attributes().style).toContain('display: none; height: 0px; top: 0px;');
});
it('should fit mode column resize end', async () => {
@ -1024,21 +1024,21 @@ describe('DataTable.vue', () => {
}
});
const resizer = wrapper.findAll('.p-column-resizer')[0];
const resizer = wrapper.findAll('.p-datatable-column-resizer')[0];
await wrapper.vm.onColumnResizeStart({ target: resizer.element });
await wrapper.vm.onColumnResizeEnd();
expect(wrapper.find('.p-column-resizer-helper').attributes().style).toContain('display: none;');
expect(wrapper.find('.p-datatable-column-resize-indicator').attributes().style).toContain('display: none;');
});
// column reorder
it('should reorder columns', async () => {
await wrapper.setProps({ reorderableColumns: true });
expect(wrapper.find('.p-datatable-reorder-indicator-up').exists()).toBe(true);
expect(wrapper.find('.p-datatable-reorder-indicator-down').exists()).toBe(true);
expect(wrapper.find('.p-datatable-row-reorder-indicator-up').exists()).toBe(true);
expect(wrapper.find('.p-datatable-row-reorder-indicator-down').exists()).toBe(true);
});
// row reorder
@ -1062,7 +1062,7 @@ describe('DataTable.vue', () => {
}
});
expect(wrapper.findAll('.p-datatable-reorderablerow-handle').length).toBe(3);
expect(wrapper.findAll('.p-datatable-reorderable-row-handle').length).toBe(3);
});
// row group
@ -1095,8 +1095,8 @@ describe('DataTable.vue', () => {
});
expect(wrapper.find('.p-datatable-tbody').attributes().role).toBe('rowgroup');
expect(wrapper.findAll('.p-column-header-content').length).toBe(1);
expect(wrapper.find('.p-column-header-content').text()).toBe('Code');
expect(wrapper.findAll('.p-datatable-column-header-content').length).toBe(1);
expect(wrapper.find('.p-datatable-column-header-content').text()).toBe('Code');
});
it('should have groupheader templating', () => {
@ -1126,8 +1126,8 @@ describe('DataTable.vue', () => {
}
});
expect(wrapper.findAll('.p-rowgroup-header').length).toBe(3);
expect(wrapper.find('.p-rowgroup-header').text()).toBe('GroupHeader Templating');
expect(wrapper.findAll('.p-datatable-row-group-header').length).toBe(3);
expect(wrapper.find('.p-datatable-row-group-header').text()).toBe('GroupHeader Templating');
});
it('should have groupfooter templating', () => {
@ -1157,8 +1157,8 @@ describe('DataTable.vue', () => {
}
});
expect(wrapper.findAll('.p-rowgroup-header').length).toBe(3);
expect(wrapper.find('.p-rowgroup-footer').text()).toBe('GroupFooter Templating');
expect(wrapper.findAll('.p-datatable-row-group-header').length).toBe(3);
expect(wrapper.find('.p-datatable-row-group-footer').text()).toBe('GroupFooter Templating');
});
it('should have expandable row groups and expand rows', async () => {
@ -1275,10 +1275,10 @@ describe('DataTable.vue', () => {
});
expect(wrapper.findAll('.p-datatable-thead > tr > th').length).toBe(3);
expect(wrapper.findAll('.p-datatable-tbody > tr.p-rowgroup-header').length).toBe(2);
expect(wrapper.findAll('.p-datatable-tbody > tr.p-rowgroup-header')[0].text()).toBe('Amy Elsner');
expect(wrapper.findAll('.p-datatable-tbody > tr.p-datatable-row-group-header').length).toBe(2);
expect(wrapper.findAll('.p-datatable-tbody > tr.p-datatable-row-group-header')[0].text()).toBe('Amy Elsner');
const firstToggler = wrapper.findAll('.p-row-toggler')[0];
const firstToggler = wrapper.findAll('.p-datatable-row-toggle-button')[0];
await firstToggler.trigger('click');