storage.cy.ts 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. import {
  2. loginIntercept,
  3. loginSetup,
  4. menuIntercept,
  5. menuTrigger,
  6. selectClick,
  7. validateSelect,
  8. validateDelete,
  9. validatePut,
  10. validateTableList,
  11. validateTableSearch,
  12. successIntercept,
  13. intercept,
  14. validateExport,
  15. exportIntercept,
  16. } from './utils';
  17. describe('库位管理', function() {
  18. beforeEach(function() {
  19. loginIntercept();
  20. menuIntercept();
  21. loginSetup();
  22. menuTrigger(2, 0);
  23. });
  24. beforeEach(function() {
  25. intercept(
  26. '/storage/getStorage',
  27. function({url: reqUrl, reply}) {
  28. const url = new URL(reqUrl);
  29. const search = new URLSearchParams(url.search);
  30. if (search.has('storageLocationName') && search.get('storageLocationName').length)
  31. return reply({fixture: 'storage/nameSearch'});
  32. if (search.has('storageLocationCode') && search.get('storageLocationCode').length)
  33. return reply({fixture: 'storage/codeSearch'});
  34. if (search.has('storageLocationType') && search.get('storageLocationType').length)
  35. return reply({fixture: 'storage/typeSearch'});
  36. if (search.has('isNotDisable') && search.get('isNotDisable').length)
  37. return reply({fixture: 'storage/disabledSearch'});
  38. if (search.has('id') && search.get('id').length)
  39. return reply({fixture: 'storage/info'});
  40. const page = search.get('page');
  41. reply({fixture: page === '1' ? 'storage/list1' : 'storage/list2'});
  42. },
  43. );
  44. successIntercept('/storage/addStorage');
  45. successIntercept('/storage/updateStorage');
  46. successIntercept('/storage/delStorage');
  47. exportIntercept('/storage/export');
  48. });
  49. const TABLE_NAME = 'storage_table',
  50. MODAL_NAME = 'storage_modal',
  51. LABEL = '库位';
  52. it('表格', function() {
  53. validateTableList(TABLE_NAME);
  54. });
  55. it('搜索', function() {
  56. const validate = validateTableSearch(TABLE_NAME);
  57. cy.get('#filter_storageName').type('库位');
  58. validate('searchName');
  59. cy.get('#filter_storageName').clear();
  60. cy.get('#filter_storageCode').type('code');
  61. validate('searchCode');
  62. cy.get('#filter_storageCode').clear();
  63. cy.get('#filter_storageType').type('type');
  64. validate('searchType');
  65. cy.get('#filter_storageType').clear();
  66. selectClick('filter_storageState', 1);
  67. validate('searchDisabled');
  68. });
  69. it('删除', function() {
  70. validateDelete(TABLE_NAME, LABEL);
  71. });
  72. const {validateAdd, validateEdit} = validatePut(
  73. MODAL_NAME,
  74. LABEL,
  75. );
  76. it('新增', function() {
  77. validateAdd(function() {
  78. cy.getTestId('field_storageLocationCode').type('0001');
  79. cy.getTestId('field_storageLocationName').type('名称');
  80. cy.getTestId('field_storageLocationType').type('类型');
  81. cy.getTestId('field_storageWarehouseWhere').type('1号仓库');
  82. selectClick('select_storageIsNotDisable', 1);
  83. });
  84. });
  85. it('修改', function() {
  86. validateEdit(TABLE_NAME, function() {
  87. cy.getTestId(MODAL_NAME).should('exist').and('be.visible');
  88. cy.getTestId(MODAL_NAME).find('h3').should('include.text', '修改库位');
  89. cy.getTestId('field_storageLocationCode').should('have.value', '0001');
  90. cy.getTestId('field_storageLocationName').should('have.value', '1号库位');
  91. cy.getTestId('field_storageLocationType').should('have.value', '原材料库位');
  92. cy.getTestId('field_storageWarehouseWhere').should('have.value', '1号仓库');
  93. validateSelect('select_storageIsNotDisable', '启用');
  94. });
  95. });
  96. it('导出', function() {
  97. validateExport();
  98. });
  99. });