Share this
Writing clean React code, tips for Context API, and automation testing for React JS
by Seven Peaks on Sep 10, 2021 10:18:00 AM
On August 18th 2021, Seven Peaks Software held an online webinar to discuss more on React JS Development. This topic was named Deploying React apps with confidence. Our three speakers of React JS experts shared their knowledge & expertise on how to build, test, and deploy React applications with full confidence through writing clean React code with clean-code structure, tips for react context API class component, end to end tests with the cypress testing framework, and much more!
Writing clean React code
Denis Pshenov opened this virtual webinar by presenting on his topic of: Getting hooked on the performance in clean code, with his bold statement on running clean-code as: “By running clean code, one can achieve good performance”.
“So what really is a clean code? It’s the code that is easy to extend and easy to understand. In the case of a new member that comes into the team who is unfamiliar with the codebase will be able to come in and quickly contribute to the codebase, implement new features and all the other stuff.
To implement clean code it can start with clean naming, consistency, single responsibilities, and Finding the best practices for your topic and applying them.
Fast initial render
This could be done by three actions:
- Code Splitting
- Tree Shaking
- Lazy Loading
Fast response to interactions
This could be done by two actions:
- Fast Render Functions
- Re-render only when needed
React Is fast like actually fast where 90% of the time the user doesn’t need to be worried but, there might be a time when react becomes slow. When it becomes slow, one needs to understand where it is this slow and measure how slow it is. There are few tools that can help one to diagnose and measure on the problems:
- Flame Graphs
- React Dev Tools
- React Profiler
So once you identify you have a problem on a page but don’t know why the problem is there, what did i do wrong, and etc, to answer all your questions one really needs to understand why does react re-render something?
- React re-render components when state inside of it has changed
- React re-render when parents of that components has re-rendered
When there’s a component getting re-rendered, react will go to every child of that component and re-render the child and then go into chip child of their components, all the children and and re-render all the children.
So if we re-render from the very top of the react tree it will affect all the components down to the last node and it will bring a big effect on the performance. So you might want to optimize for the re-render at the very top so that it doesn’t need to re-render from the top very often.”
Sometimes you need to actually share the state between different components, well you need a global state. For a proper global state management, you can find a lot of NPM Libraries such:
- Redux
- Context API
- Zustand (Maintained by Dashi Kato)
- Jotai (or Recoil)
- Constate
- Use Context Selector
Etc.
And there are still few other ways on the optimizations that can be done but are not based on the clean code practice:
- useMemo
- useCallback
- UseRef”
Watch the live presentation of writing clean React code below:
Getting Hooked on Performance and Clean Code by Denis.
React Context API
Our second speaker, Huad, started his talk by diving deep into context API through showing the latest tips, tricks, and the Do’s and Don’ts of context API so that you can make the most effective use out of it.
“Context provides a way to pass data through the component tree without having to pass props down manually at every level.”
– https://reactjs.org/docs/context.html
“Another way allowing you to implicitly share data (state) between components.”
– Huad himself
Huad defines context as another way that allows you to implicitly share data (state) between components. As context is for state or data sharing, fundamentally in react , data sharing is just passing prop.
“So what’s the real problem and why do you need context when you can just simply pass prop? Well, the problem will arise when you pass down multiple levels.
It’s called props drilling. It happens when you have to pass down your data or prop into multiple levels, and the intermediate component doesn’t have to know about this data. Which is troublesome and annoying for some people.
So the problem caused by props drilling could be solved by the context API. The first thing we import is a function called create context from react. And it takes only one parameter, which is the default value that we just put undefined , or if you use TypeScript you have to pass this.
If you use JavaScript we can just leave it there. When calling create context you in return, you’ll get a context instance object. Then, that you have context, and how to use it.
So, in the result of calling create context you get the context object instance, and then in the instant property you add a component called provider. So, you just need to create the component with the one required prop, which is value, this value we’ll be using when you consume the context.
You just create a component and wrap it. Everything inside. So when consuming the context. You just use another hook from react, called use context, and pass the context, instead.
In return, it gives you the value that you just passed in the provider before, which is the object that contains the current color and sip color.”
Watch the live coding demonstration of React API Context below:
React API Context by Huad.
Testing Pyramid: Cypress testing framework, React testing library, and more
Our last speaker, Georgii, walked us through how to deploy your React Applications with confidence by performing practical testing, through using the Testing Pyramid, with the React Testing Library and Cypress.
Georgii starts off by explaining what you’ll need to expect when making a release to then delivering an application:
- New features work as expected
- There are no bugs
- There is no regression
“So why we should write test in our front end application:
- Clients hates bugs in their final product
- Refactoring, especially in the big part of the code is is painful as you might be worry that you will break something
- Regressions in the product that are already in production can have very high costs
- It is to save money and time
The basic concept of the testing could be in the form of testing pyramid
- 1st Level is unit tests
- 2nd Level are integration tests
- 3rd level is end testing
This concept or methodology can easily apply for the backend. On the unit tests, basically if you do, especially TDD, it’s much more like you write a unit test before you write into code.
Integration test you write a little bit less, but you just check how, let’s say API works just call API, and see, is it responding correctly, an endpoint, it’s mostly like postman or something like this you call rail API and see with real data, what’s going on.
But in the backend, you see failure right away, end to end tests, but each type of test has its own benefits.
Moving on to the testing trophy, Georgii starts with the basement of the concept which is static checks continued by unit tests, integration tests and end to end tests.
So what tools can be used on each test?
- Static Checks – Typescript, EsLint, Flow
- Unit Tests – Jest
- Integration Tests – Jest + React testing library
- End to End Tests – Cypress”
“Write tests. Not too many. Mostly integration.”
– Guillermo Rauch
Watch the live coding demonstration of integration & end to end testing below:
Testing Pyramid by Georgii.
Share this
- FinTech (13)
- Career (12)
- Expert Spotlight (11)
- Thought Leadership (11)
- Product Growth (9)
- Software Development (9)
- Product Design (7)
- Data and Analytics (6)
- Design Thinking (5)
- InsurTech (5)
- QA (5)
- AI (4)
- Agile (4)
- Cloud (4)
- Company (4)
- Data (4)
- Digital Transformation (4)
- Financial Inclusion (4)
- JavaScript (4)
- Seven Peaks Insights (4)
- Trend (4)
- UX Design (4)
- UX Research (4)
- .NET (3)
- Android Developer (3)
- Android Development (3)
- Azure (3)
- Banking (3)
- CSR (3)
- DevOps (3)
- Digital Product (3)
- IoT (3)
- Product-Centric Mindset (3)
- CDP (2)
- Cloud Development (2)
- Customer Data Platform (2)
- E-wallet (2)
- Expat (2)
- Hybrid App (2)
- Kotlin (2)
- Product Owner (2)
- Software Tester (2)
- SwiftUI (2)
- UI (2)
- UX (2)
- UX Writing (2)
- Visual Design (2)
- iOS Development (2)
- .NET 8 (1)
- 2023 (1)
- 4IR (1)
- 5G (1)
- API (1)
- Agritech (1)
- AndroidX Biometric (1)
- App Development (1)
- Azure OpenAI Service (1)
- Backend (1)
- Brand Loyalty (1)
- CI/CD (1)
- Conversions (1)
- Cross-Platform Application (1)
- Dashboard (1)
- Digital (1)
- Digital Healthcare (1)
- Digital ID (1)
- Digital Landscape (1)
- Engineer (1)
- Expert Interview (1)
- Fiddler (1)
- Figma (1)
- Financial Times (1)
- GraphQL (1)
- Hilt (1)
- IT outsourcing (1)
- KYC (1)
- MVP (1)
- MVVM (1)
- Metaverse (1)
- Morphosis (1)
- Native App (1)
- New C# (1)
- Newsletter (1)
- Node.js (1)
- Payment (1)
- Platform Engineer (1)
- Platform Engineering Jobs (1)
- Platform Engineering Services (1)
- Project Manager (1)
- Rabbit MQ (1)
- React (1)
- ReactJS (1)
- Stripe (1)
- Super App (1)
- Turnkey (1)
- UIkit (1)
- UX Strategy (1)
- Web 3.0 (1)
- Web-Debugging Tool (1)
- January 2025 (2)
- December 2024 (4)
- November 2024 (2)
- September 2024 (4)
- August 2024 (3)
- July 2024 (6)
- April 2024 (1)
- March 2024 (7)
- February 2024 (14)
- January 2024 (13)
- December 2023 (9)
- November 2023 (9)
- October 2023 (2)
- September 2023 (6)
- August 2023 (6)
- June 2023 (4)
- May 2023 (4)
- April 2023 (1)
- March 2023 (1)
- November 2022 (1)
- August 2022 (4)
- July 2022 (1)
- June 2022 (6)
- April 2022 (6)
- March 2022 (4)
- February 2022 (8)
- January 2022 (4)
- December 2021 (1)
- November 2021 (2)
- October 2021 (2)
- September 2021 (1)
- August 2021 (3)
- July 2021 (1)
- June 2021 (2)
- May 2021 (1)
- March 2021 (4)
- February 2021 (5)
- December 2020 (4)
- November 2020 (1)
- June 2020 (1)
- April 2020 (1)