-
Notifications
You must be signed in to change notification settings - Fork 70
Engineering Practices
Flacial edited this page Jan 13, 2022
·
25 revisions
Best practice to follow
- when you run
npm run test
, there's a column calledUncovered Lines
that tells you which lines are not tested
- All of your commits must be tagged with an issue number. If your commit fixes / resolves an issue, make sure it says in your commit. For example:
git commit -m 'close #42 - adds username validation for length'
- You must break down an issue into multiple PRs if the issue is complex.
git commit -m 'update #42 - creates new service function to create login session'
- Don't have huge PRs -- if you are making a component for example, then make that component and its accompanying stories for one PR, and implement it onto the website the next PR.
- Do not lower 100% Code Coverage
- Do not use
a
anchor tags unless it is to a different domain. Must useLink
component for client side rendering. - Frontend - When creating new routes, always use lowercase. Don't use camel case since the route can be case sensitive (i.e. use
https://www.c0d3.com/sendemail
instead ofhttps://www.c0d3.com/sendEmail
) - Storybook - If you build a reusable component, please create a component with all the possible states in your component so other devs know how to use that component.
- In the backend - On invalid responses, always throw. Example signup resolver
- GraphQL - use
yarn generate
when modifying code inside the /graphql/ folder to generate TS code to be used with GraphQL front-end- Local server must be running on port 3000
- On front end, instead of using throw, use Sentry.captureException instead. (add API link later)
- On the back end, use internal logger function to log error to sentry
- Create a Design Doc for any large or complex issues or features. Need to figure out why you need one? Read about Design Docs at Google. List of design docs