pnpm start
launches the app in development mode at http://localhost:3000pnpm test
launches the test runner in the interactive watch modepnpm run serve
serves the static assets from thebuild
directorypnpm run build
builds the app into thebuild
directory- compatible with these browsers.
- bundles React in production mode and optimizes the build for the best performance:
- compatible with these browsers.
Install Redux Devtools Chrome Extension Install Node.js LTS 10.14.1 using nvm and run
cp -p .env.development .env
npm install -g pnpm
pnpm install
pnpm start
It is assumed that the clin-proxy-services are running locally on your machine.
Make sure you followed the instructions to have a Dockerized setup for the clin proxy api services: https://github.com/cr-ste-justine/clin-proxy-api#dockerized-version
Then, run:
cp env.docker.remote .env
docker-compose up -d
To stop, run:
docker-compose down
All references to other services point to the QA. A 100% local version will come in the future.
See the documentation for our convention on gitflow and docker images: https://www.notion.so/ferlab/Developer-Handbook-ca9d689d8aca4412a78eafa2dfa0f8a8
Updates to the QA environment are automatically done once a new image is pushed. No action is required.
Procedures to deploy to prod will be fleshed out once we have such an environment.
yarn test
/ npm run test
Locally this command will run in --watch
mode and on CI it won't
- The
onFinish
event handler on theForm
component doesn't seems to run when you useform.submit()
whereform
comes fromuseForm()
.- To fix this, I used the
onSubmitCapture
to run the same function asonFinish
-
onSubmitCapture={() => { onFormSubmit(form.getFieldsValue()); }} onFinish={(values) => { onFormSubmit(values); }}
-
- To fix this, I used the
- The
Select
component from Ant D isn't testable (you cannot open it and select an option)- The workaround is to mock it with the html
select
. Since the problem is global, the mock is done insetupTests.tsx
. This way it's automatically applied for every tests. Some feature might not be supported currently but it can be modified/addapted to support them.
- The workaround is to mock it with the html
- When using "Nested"
Form.Item
(usingname={['mrn', 'organization']}
), AntD doesn't assign anyname
property on theinput
field. This makes it impossible to select theinput
with the label (best) or by role and filtering by name.- You have to add the
data-testid
property supported by react-testing-library- More info on the library documentation
- You have to add the
yarn cypress:open
/npm run cypress:open
- The app must be running (
yarn start
) in parallel for it to work - Best for tests development
- The app must be running (
yarn cypress:run:chrome
/npm run cypress:run:chrome
- This command will open a Chrome instance, run the tests and close the Chrome instance
- The closest to what runs on CI
yarn cypress:run:cli
/npm run cypress:run:cli
- This command will run tests in a chromium instance
- The fastest