user.cy.ts 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. import {
  2. loginIntercept,
  3. loginSetup,
  4. menuIntercept,
  5. optionsIntercept,
  6. menuTrigger,
  7. selectClick,
  8. validateSelect,
  9. validateDelete,
  10. validatePut,
  11. validateTableList,
  12. validateTableSearch,
  13. successIntercept,
  14. intercept,
  15. validateExport,
  16. exportIntercept,
  17. } from './utils';
  18. describe('用户管理', function() {
  19. beforeEach(function() {
  20. loginIntercept();
  21. menuIntercept();
  22. loginSetup();
  23. optionsIntercept();
  24. menuTrigger(1, 0);
  25. });
  26. beforeEach(function() {
  27. intercept(
  28. '/user/getAllUser',
  29. function({reply, url: reqUrl}) {
  30. const url = new URL(reqUrl);
  31. const search = new URLSearchParams(url.search);
  32. if (search.has('userName') && search.get('userName').length)
  33. return reply({fixture: 'user/nameSearch'});
  34. if (search.has('code') && search.get('code').length)
  35. return reply({fixture: 'user/codeSearch'});
  36. if (search.has('id') && search.get('id').length)
  37. return reply({fixture: 'user/userInfo'});
  38. const page = search.get('page');
  39. reply({fixture: page === '1' ? 'user/userList1' : 'user/userList2'});
  40. },
  41. );
  42. successIntercept('/user/delUser');
  43. successIntercept('/user/addUser');
  44. successIntercept('/user/updateUser');
  45. exportIntercept('/user/userExport');
  46. });
  47. const TABLE_NAME = 'user_table',
  48. MODAL_NAME = 'user_add_modal',
  49. LABEL = '用户';
  50. it('用户列表', function() {
  51. validateTableList(TABLE_NAME);
  52. });
  53. it('搜索', function() {
  54. const validate = validateTableSearch(TABLE_NAME);
  55. cy.get('.ant-pagination').find('li[title="2"]').click();
  56. cy.get('input[name="useName"]').type('admin');
  57. cy.get('input[name="useCode"]').clear();
  58. validate('searchName');
  59. cy.get('input[name="useName"]').clear();
  60. cy.get('input[name="useCode"]').type('1234');
  61. validate('searchCode');
  62. });
  63. it('删除操作', function() {
  64. validateDelete(TABLE_NAME, LABEL);
  65. });
  66. const {validateAdd, validateEdit} = validatePut(
  67. MODAL_NAME,
  68. LABEL,
  69. );
  70. it('新增操作', function() {
  71. validateAdd(function() {
  72. cy.get('input[name="userName"]').type('name');
  73. cy.get('input[name="userPassword"]').type('password');
  74. cy.get('input[name="userRealName"]').type('realname');
  75. cy.get('input[name="userEmail"]').type('email');
  76. cy.get('input[name="userLandline"]').type('userLandline');
  77. cy.get('input[name="userPhone"]').type('userPhone');
  78. selectClick('select_userDepartment', 0);
  79. selectClick('select_userRole', 0);
  80. });
  81. });
  82. it('修改操作', function() {
  83. validateEdit(TABLE_NAME, function() {
  84. cy.get('input[name="userName"]').should('have.value', '123412');
  85. cy.get('input[name="userPassword"]').should(
  86. 'have.value',
  87. '44349BD19046F3D527D67A5D0D414B09');
  88. cy.get('input[name="userRealName"]').should('have.value', '测试');
  89. cy.get('input[name="userEmail"]').should('have.value', '123@adfa.com');
  90. cy.get('input[name="userLandline"]').should('have.value', '1231123');
  91. cy.get('input[name="userPhone"]').should('have.value', '1532');
  92. validateSelect('select_userDepartment', '物流部门');
  93. validateSelect('select_userRole', '物流管理员');
  94. });
  95. });
  96. it('导出', function() {
  97. validateExport();
  98. });
  99. });