utils.ts 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. export function selectClick(testid: string, eq = 0) {
  2. cy.getTestId(testid).click();
  3. cy.getTestId(testid).find('.rc-virtual-list-holder-inner')
  4. .children().eq(eq).click();
  5. }
  6. export function intoMenu(parent: string, child: string) {
  7. cy.getTestId('menu').children().each(function(el) {
  8. const titleElement = el.find('.ant-menu-submenu-title');
  9. if (titleElement.text() === parent) {
  10. titleElement.trigger('click');
  11. el.find(`ul>li[title="${child}"]`).trigger('click');
  12. }
  13. });
  14. }
  15. export function validateSelect(testid: string, value: string) {
  16. cy.getTestId(testid).find('.ant-select-selection-item')
  17. .should('have.attr', 'title', value).and('have.text', value);
  18. }
  19. export function validateTableList(tableName: string, firstPageNumber = 3, secondPageNumber = 2) {
  20. cy.getTestId(tableName).find('table').find('.ant-table-tbody')
  21. .children('.ant-table-row').should('have.length', firstPageNumber);
  22. cy.getTestId(tableName).siblings('.ant-pagination').find('li[title="2"]').click();
  23. cy.getTestId(tableName).find('table').find('.ant-table-tbody')
  24. .children('.ant-table-row').should('have.length', secondPageNumber);
  25. }
  26. export function validateTableSearch(
  27. tableName: string,
  28. value?: string,
  29. options?: {btnTestId?: string},
  30. ) {
  31. cy.getTestId(tableName).siblings('.ant-pagination').find('li[title="2"]')
  32. .click();
  33. const {btnTestId} = options ?? {};
  34. return function(text?: string) {
  35. cy.getTestId(btnTestId ?? 'search_btn').click();
  36. cy.getTestId(btnTestId ?? 'search_btn').should('have.class', 'ant-btn-loading');
  37. cy.getTestId(tableName).find('table').find('.ant-table-tbody')
  38. .children('.ant-table-row').first().find('td').first()
  39. .should('include.text', text ?? value);
  40. cy.getTestId(btnTestId ?? 'search_btn')
  41. .should('not.have.class', 'ant-btn-loading');
  42. cy.getTestId(tableName).siblings('.ant-pagination').find('li[title="1"]')
  43. .should('have.class', 'ant-pagination-item-active');
  44. };
  45. }
  46. export function tableBtnClick(tableName: string, index: number) {
  47. cy.getTestId(tableName).find('table').find('.ant-table-tbody')
  48. .children('.ant-table-row').first().find('td').last().children().eq(index)
  49. .click();
  50. }
  51. export function validateModalBtnGroup(modalName: string) {
  52. cy.getTestId(modalName).getTestId('modal_btn_group').find('.ant-btn').first()
  53. .should('have.class', 'ant-btn-loading');
  54. cy.getTestId(modalName).getTestId('modal_btn_group').find('.ant-btn').last()
  55. .should('have.attr', 'disabled');
  56. }
  57. export function validateModalOperation(modalName: string, text: string) {
  58. cy.getTestId(modalName).find('form').submit();
  59. validateModalBtnGroup(modalName);
  60. cy.get('.ant-message-notice-content').should('include.text', text);
  61. cy.getTestId(modalName).should('not.exist');
  62. }
  63. export function validatePut(
  64. modalName: string,
  65. label: string,
  66. options?: {addBtnTestId?: string},
  67. ) {
  68. const {addBtnTestId} = options ?? {};
  69. function validateAdd(fn: () => void) {
  70. cy.getTestId(addBtnTestId ?? 'add_btn').click();
  71. cy.getTestId(modalName).should('exist').and('be.visible');
  72. cy.getTestId(modalName).find('h3')
  73. .should('include.text', `新增${label}`);
  74. fn();
  75. validateModalOperation(modalName, '新增成功');
  76. }
  77. function validateEdit(tableName: string, validateFn: () => void) {
  78. tableBtnClick(tableName, 0);
  79. cy.getTestId(modalName).should('exist').and('be.visible');
  80. cy.getTestId(modalName).find('h3').should('include.text', `修改${label}`);
  81. validateFn();
  82. validateModalOperation(modalName, '修改成功');
  83. }
  84. return {validateAdd, validateEdit};
  85. }
  86. export function validateDelete(
  87. tableName: string,
  88. label: string,
  89. ) {
  90. tableBtnClick(tableName, 1);
  91. cy.get('.ant-modal-content').should('be.visible');
  92. cy.get('.ant-modal-confirm-title').should('include.text', `删除${label}`);
  93. cy.get('.ant-modal-confirm-content').should(
  94. 'include.text',
  95. `你确定要删除当前${label}吗?`,
  96. );
  97. cy.get('.ant-modal-confirm-btns').children().last().trigger('click');
  98. cy.getTestId(tableName).find('table').find('.ant-table-tbody')
  99. .children('.ant-table-row').first().find('td').last().children().eq(1)
  100. .should('have.class', 'ant-btn-loading');
  101. cy.getTestId(tableName).find('table').find('.ant-table-tbody')
  102. .children('.ant-table-row').first().find('td').last().children().first()
  103. .should('have.attr', 'disabled');
  104. cy.get('.ant-message-notice-content').should('include.text', '删除成功');
  105. }
  106. export function validateExport(testid?: string) {
  107. cy.getTestId(testid ?? 'export_btn').click();
  108. cy.getTestId(testid ?? 'export_btn').should('have.class', 'ant-btn-loading');
  109. cy.wait('@export');
  110. cy.getTestId(testid ?? 'export_btn').should('not.have.class', 'ant-btn-loading');
  111. }
  112. export function closeModal() {
  113. cy.get('.ReactModal__Overlay')
  114. .trigger(
  115. 'click',
  116. 'topRight',
  117. );
  118. }
  119. export function clickDatePicker(id: string) {
  120. cy.getTestId(id).click();
  121. cy.get('.ant-picker-panels').children().eq(0).find('.ant-picker-content')
  122. .find('tbody').find('td').eq(0).click();
  123. cy.get('.ant-picker-panels').children().eq(1).find('.ant-picker-content')
  124. .find('tbody').find('td').eq(0).click();
  125. }