Skip to content

Commit

Permalink
Merge branch 'develop' into issue/9733/user-create-edit
Browse files Browse the repository at this point in the history
  • Loading branch information
rajku-dev authored Jan 13, 2025
2 parents f580cd8 + fc4c3d5 commit 819724b
Show file tree
Hide file tree
Showing 50 changed files with 2,215 additions and 1,881 deletions.
2 changes: 1 addition & 1 deletion .env
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ REACT_APP_COVER_IMAGE_ALT=https://cdn.ohc.network/care_logo.svg
REACT_PUBLIC_URL=https://care.ohc.network

# Care API URL without the /api prefix
REACT_CARE_API_URL=https://care-api.do.ohc.network
REACT_CARE_API_URL=https://careapi.ohc.network

# Dev envs
ESLINT_NO_DEV_ERRORS=true
Expand Down
8 changes: 8 additions & 0 deletions care.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,14 @@ const careConfig = {
},

appointments: {
/**
* Relative number of days to show in the appointments page by default.
* 0 means today, positive for future days, negative for past days.
*/
defaultDateFilter: env.REACT_APPOINTMENTS_DEFAULT_DATE_FILTER
? parseInt(env.REACT_APPOINTMENTS_DEFAULT_DATE_FILTER)
: 7,

// Kill switch in-case the heatmap API doesn't scale as expected
useAvailabilityStatsAPI: boolean(
"REACT_APPOINTMENTS_USE_AVAILABILITY_STATS_API",
Expand Down
22 changes: 21 additions & 1 deletion cypress/docs/best-practices.md
Original file line number Diff line number Diff line change
@@ -1,32 +1,52 @@
# Best Practices

## Test Independence

- Each test should be independent and isolated
- Clean up test data after tests
- Don't rely on the state from other tests

## API Testing

- Use cy.intercept() for API verification
- Use waitUntil() for API completion
- Avoid cy.wait() except for API responses

## Element Interaction

- Always verify element state before interaction
- Use data-cy attributes for selectors
- Verify button text before clicking
- Always verify loading states before and after interactions

## Code Organization

- Keep tests focused and concise
- Follow AAA pattern (Arrange, Act, Assert)
- Use meaningful test descriptions

## Common Pitfalls to Avoid

- Redundant visibility checks with verifyAndClickElement
- Hardcoded values in page objects
- Unnecessary waits
- Test interdependencies
- Skipping API verifications
- Using arbitrary timeouts instead of proper waits

## Performance Considerations

- Minimize unnecessary API calls
- Use efficient selectors
- Batch similar operations
- Batch similar operations

## Testing Checklist

Before submitting your test, verify:

- [ ] All API calls are intercepted and verified
- [ ] Loading states are handled properly
- [ ] Success/error states are verified
- [ ] No arbitrary timeouts used
- [ ] Search operations include debounce handling
- [ ] Form submissions verify both request and response
26 changes: 19 additions & 7 deletions cypress/docs/file-structure.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
# File Structure and Organization

## Directory Structure

```
cypress/
├── docs/
Expand All @@ -9,31 +10,42 @@ cypress/
│ ├── patterns.md
│ └── best-practices.md
├── e2e/ # Test files grouped by modules
│ ├── patient/
│ ├── facility/
│ └── user/
├── fixtures/
├── pageObject/
└── support/
│ ├── patient/
│ ├── facility/
│ └── user/
├── fixtures/
├── pageObject/ # Page Objects grouped by modules
│ ├── patient/
│ ├── facility/
│ └── user/
├── utils/ # Utility functions and helpers
│ ├── facilityData.ts # Facility-related utility functions
│ └── commonUtils.ts # Shared utility functions
└── support/
```

## Module Organization

Each module (patient, facility, user, etc.) should have:

- Test files in `e2e/<module-name>/`
- Page Object in `pageObject/<module-name>/`
- Fixtures in `fixtures/<module-name>/`

## File Naming Conventions

- Test files: `feature-name.cy.ts`
- Page Object: `FeatureNamePage.ts`
- Custom Commands: `feature-name.ts`
- Fixtures: `feature-name-data.json`

## Support Files

- `commands.ts`: Custom Cypress commands
- `e2e.ts`: e2e configurations
- `index.ts`: Main support file

## Storage Management

- Use cy.saveLocalStorage() and cy.restoreLocalStorage()
- Manage test data cleanup
- Manage test data cleanup
3 changes: 3 additions & 0 deletions cypress/e2e/facility_spec/facility_creation.cy.ts
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,9 @@ describe("Facility Management", () => {
facilityPage.submitFacilityCreationForm();
facilityPage.verifySuccessMessage();

// Wait for facility cards to load
facilityPage.waitForFacilityCardsToLoad();

// Search for the facility and verify in card
facilityPage.searchFacility(testFacility.name);
facilityPage.verifyFacilityNameInCard(testFacility.name);
Expand Down
14 changes: 13 additions & 1 deletion cypress/pageObject/facility/FacilityCreation.ts
Original file line number Diff line number Diff line change
Expand Up @@ -95,10 +95,22 @@ export class FacilityCreation {
}

searchFacility(facilityName: string) {
cy.typeIntoField('[data-cy="search-facility"]', facilityName);
cy.intercept("GET", `**/api/v1/facility/?**`).as("searchFacility");

cy.get('[data-cy="search-facility"]')
.focus()
.type(facilityName, { force: true });

cy.wait("@searchFacility").its("response.statusCode").should("eq", 200);
}

verifyFacilityNameInCard(facilityName: string) {
cy.get('[data-cy="facility-cards"]').should("contain", facilityName);
}

waitForFacilityCardsToLoad(timeout = 10000) {
cy.get('[data-cy="facility-cards"]', { timeout })
.should("be.visible")
.should("not.be.empty");
}
}
30 changes: 21 additions & 9 deletions cypress/support/commands.ts
Original file line number Diff line number Diff line change
Expand Up @@ -235,20 +235,32 @@ Cypress.Commands.add(
(
selector: string,
value: string,
options: { clearBeforeTyping?: boolean; skipVerification?: boolean } = {},
options: {
clearBeforeTyping?: boolean;
skipVerification?: boolean;
delay?: number;
} = {},
) => {
const { clearBeforeTyping = false, skipVerification = false } = options;
const {
clearBeforeTyping = false,
skipVerification = false,
delay = 0,
} = options;
const inputField = cy.get(selector);

if (clearBeforeTyping) {
inputField.clear(); // Clear the input field if specified
inputField.clear();
}

inputField.scrollIntoView().should("be.visible").click().type(value);

// Conditionally skip verification based on the skipVerification flag
if (!skipVerification) {
inputField.should("have.value", value); // Verify the value if skipVerification is false
}
inputField
.scrollIntoView()
.should("be.visible")
.click()
.type(value, { delay })
.then(() => {
if (!skipVerification) {
cy.get(selector).should("have.value", value);
}
});
},
);
6 changes: 5 additions & 1 deletion cypress/support/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,11 @@ declare global {
typeIntoField(
selector: string,
value: string,
options?: { clearBeforeTyping?: boolean; skipVerification?: boolean },
options?: {
clearBeforeTyping?: boolean;
skipVerification?: boolean;
delay?: number;
},
): Chainable<Element>;
}
}
Expand Down
27 changes: 13 additions & 14 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -77,8 +77,8 @@
"@radix-ui/react-toast": "^1.2.4",
"@radix-ui/react-tooltip": "^1.1.6",
"@sentry/browser": "^8.48.0",
"@tanstack/react-query": "^5.62.8",
"@tanstack/react-query-devtools": "^5.63.0",
"@tanstack/react-query": "^5.64.0",
"@tanstack/react-query-devtools": "^5.64.0",
"@vitejs/plugin-react": "^4.3.4",
"@yudiel/react-qr-scanner": "^2.1.0",
"bowser": "^2.11.0",
Expand Down
Loading

0 comments on commit 819724b

Please sign in to comment.