1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00
unleash.unleash/frontend/cypress
Thomas Heartman b5de65bb8e
chore: wait to input the name of the segment when checking for error messages ()
This change adds a wait statement before entering the name of the
segment when checking for error messages that this segment name
already exists.

This is the same workaround that we did in
https://github.com/Unleash/unleash/pull/7289, which seems to have
worked.

Like in that PR, using waits is still an antipattern, but it appears
to be working.

Maybe it’s time to look more deeply at why it happens? Why isn’t the
field ready to receive input even though it’s on the page? Is it mui’s
fault or ours?
2024-06-12 14:06:44 +02:00
..
fixtures feat: e2e tests and mobile views () 2021-09-30 11:44:30 +02:00
integration chore: wait to input the name of the segment when checking for error messages () 2024-06-12 14:06:44 +02:00
oss/feature chore: rename toggle to flag () 2024-05-22 08:20:11 +03:00
support chore: make feature.spec and segements.spec more resilient () 2024-06-07 08:37:53 +02:00
global.d.ts chore: test migration backward compatibility () 2023-11-30 18:20:13 +01:00
README.md chore: refactor Cypress tests () 2023-04-04 11:46:28 +03:00
tsconfig.json chore: refactor Cypress tests () 2023-04-04 11:46:28 +03:00

Unleash Behavioural tests

Add common commands to Cypress

  • global.d.ts is where we extend Cypress types
  • API.ts contains api requests for common actions (great place for cleanup actions)
  • UI.ts contains common functions for UI operations
  • commands.ts is the place to map the functions to a cypress command

Test Format

Ideally each test should manage its own data.

Avoid using after and afterEach hooks for cleaning up. According to Cypress docs, there is no guarantee that the functions will run

Suggested Format:

  • prepare
  • when
  • then
  • clean

Passing (returned) parameters around

it('can add, update and delete a gradual rollout strategy to the development environment', async () => {
    cy.addFlexibleRolloutStrategyToFeature_UI({
        featureToggleName,
    }).then(value => {
        strategyId = value;
        cy.updateFlexibleRolloutStrategy_UI(featureToggleName, strategyId).then(
            () => cy.deleteFeatureStrategy_UI(featureToggleName, strategyId)
        );
    });
});