commands.ts 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. // ***********************************************
  2. // This example commands.js shows you how to
  3. // create various custom commands and overwrite
  4. // existing commands.
  5. //
  6. // For more comprehensive examples of custom
  7. // commands please read more here:
  8. // https://on.cypress.io/custom-commands
  9. // ***********************************************
  10. //
  11. //
  12. // -- This is a parent command --
  13. // Cypress.Commands.add('login', (email, password) => { ... })
  14. //
  15. //
  16. // -- This is a child command --
  17. // Cypress.Commands.add('drag', { prevSubject: 'element'}, (subject, options) => { ... })
  18. //
  19. //
  20. // -- This is a dual command --
  21. // Cypress.Commands.add('dismiss', { prevSubject: 'optional'}, (subject, options) => { ... })
  22. //
  23. //
  24. // -- This will overwrite an existing command --
  25. // Cypress.Commands.overwrite('visit', (originalFn, url, options) => { ... })
  26. Cypress.Commands.add('getByTestid', (selector, options?) => {
  27. return cy.get(`[data-testid=${selector}]`, options);
  28. });
  29. Cypress.Commands.add('login', (username, password) => {
  30. cy.session(username, () => {
  31. cy.visit('/page-to-return-after-login');
  32. cy.getByTestid('tiUsernameForLogin').type(username);
  33. cy.getByTestid('tiPasswordForLogin').type(password);
  34. cy.intercept('POST', '/_api/v3/login').as('login');
  35. cy.getByTestid('btnSubmitForLogin').click();
  36. cy.wait('@login')
  37. });
  38. });
  39. /**
  40. * use only for the pages which use component with skeleton
  41. */
  42. Cypress.Commands.add('waitUntilSkeletonDisappear', () => {
  43. cy.get('.grw-skeleton').should('exist');
  44. cy.get('.grw-skeleton').should('not.exist');
  45. });
  46. Cypress.Commands.add('waitUntilSpinnerDisappear', () => {
  47. cy.get('.fa-spinner').should('exist');
  48. cy.get('.fa-spinner').should('not.exist');
  49. });
  50. let isSidebarCollapsed: boolean | undefined;
  51. Cypress.Commands.add('collapseSidebar', (isCollapsed, force=false) => {
  52. if (!force && isSidebarCollapsed === isCollapsed) {
  53. return;
  54. }
  55. const isGrowiPage = Cypress.$('div.growi').length > 0;
  56. if (!isGrowiPage) {
  57. cy.visit('/page-to-toggle-sidebar-collapsed');
  58. }
  59. cy.getByTestid('grw-contextual-navigation-sub').then(($contents) => {
  60. const isCurrentCollapsed = $contents.hasClass('d-none');
  61. // toggle when the current state and isCoolapsed is not match
  62. if (isCurrentCollapsed !== isCollapsed) {
  63. cy.getByTestid("grw-navigation-resize-button").click({force: true});
  64. // wait until saving UserUISettings
  65. // eslint-disable-next-line cypress/no-unnecessary-waiting
  66. cy.wait(1500);
  67. }
  68. });
  69. isSidebarCollapsed = isCollapsed;
  70. });