How do I gather and prioritize the performance requirements of a student from schools, colleges, universities and society?
Note that, I said performance. What do performance mean in schools, colleges, universities and society?
- Any time, you asked this question to self?
- If you are living with children, did this question cross your mind, no matter in what class the children are studying?
How do you gather and prioritize performance requirements from stakeholders and project documentation?
Prioritizing Performance & Its Requirements
That said, what is performance for Netflix is not same for the Aadhar system. But, both have prioritized the performance and looks to be aggressive in knowing the requirements for same. Don't you think so?
We're in the timeline of Shift Left.
- How to shift with performance to left?
- What all in the system should focus on the performance in the Shift Left?
MVP & Performance Engineering Story
When we are going to take MVP as early as possible to market, there is a tradeoff. What are considered in subsequent priorities which will be compromised on negotiation by engineering and business?
The context matters when prioritizing! Be it for performance or functionality or security or any quality criteria.
I will interpret the question asked from the point view of a MVP's deployment or publishing.
- Are you asking why I have picked MVP?
- The performance is contextual and it is based out on multiple touchpoints, its boundaries and interfaces of a system.
- I cannot talk on all those in this blog post.
- Neither, I want to talk about the KPIs and metrics.
- I want to share which you can pick, consume, and apply in your work.
Now, we have prioritized performance for a MVP. Aren't we? Prioritized means, it matters, it concerns us and we are okay to compromise on few for it. Let us jump to Left with MVP in our hands to identify the requirements of business.
As a business, we will have a rough idea on how we are pitching and selling our services and to whom. As a test engineer, you can sense what is the key transaction [business work flow] in the MVP. You will know the touchpoints, interfaces and boundaries in the architecture that communicates and work together to keep MVP delivering the value. Don't you?
Say the business wants the MVP to support and serve 500 requests per second. I should know about the 500 requests here.
Is it,
- Concurrent Requests?
- Active Concurrent Requests?
This matters! Both are not the same. Have you asked this question? It is a requirement we miss to capture.
Capturing Performance Questions for a MVP
It is about the awareness for first! How much am I opening up myself to the awareness? This brings an energy and it is contagious.
How do I bring the performance awareness in my team so that it is engineered into the system we develop? This is a culture drive to an organization.
Now, I know, the MVP has to serve 500 concurrent active users in a second per business's expectation to meet its reach and target. If I do not know this, I have to capture this data, for first. How do you capture?
A Use Case to Ponder
One use case which would trigger the spark of thinking is - How should Disney+ Hotstar's services perform to live stream the India vs Pakistan Cricket World Cup 2023 on 14th Oct 2023?
- How should it capture the performance and its requirement for this day?
- How should this system scale to crores of viewers streaming the live video of the match?
- How should this system scale for the gamification - emoji, chat and other viewers engagement during the crores of viewers making requests from client interface?
Step Up by 5% Heuristic
- What is the 5% of 500?
- I will start with 25 concurrent active users requests for the MVP.
- I will observe the emotional experience of when using the MVP during this time.
- I will monitor and record the KPIs, and other needed data.
- Does it fail to serve 5% of concurrent active users?
- If failed, I know what to do now. It helped me.
- This helps me to draw the requirements better and rationally for the existing system's architecture.
- If it succeeds, it helped me partially in knowing what actually I wanted to know.
- I will raise the active concurrent users to 10%
- That is, increasing it by 5%
- I repeat these tests until the MVP architecture lets me know about the requirement it needs for the performance of serving 500 active concurrent users in a second
- Read the above sentence, again
- The tests on MVP will let me learn what are its performance requirements for serving active concurrent 500 users in a given architecture, infrastructure, and tech stacks
Beyond by 37% Heuristic
- If seen, I have 1.5x traffic now. Did it serve?
- If yes, how many active concurrent users were served in a second?
- I will correlate the KPIs of other integrated systems of a MVP.
- With the captured data and emotions
- This will tell, what should we expect despite what is the expectation from business
- This difference will let us know "the requirements"
- How to gather information on -- what has to be optimized, changed, reorchestrated, eliminated, included, and more.
- We start technically in establishing and framing the Performance SLAs and SLOs between the tech team and business.
- Now the performance & its requirements will appear in the dots that are,
- Being connected
- To be connected
- To be disconnected
- That does not exist
- Performance Testing: Unspoken KPIs and The Missing Correlation
- Architecture: The Common Shared Understanding -- Part 1
- Architecture: Its Aid in Performance Engineering -- Part 2
No comments:
Post a Comment
Please, do write your comment on the read information. Thank you.