Practical Guide to Test Automation in Software Testing
Author: The MuukTest Team
Last updated: October 1, 2024
data:image/s3,"s3://crabby-images/5acc1/5acc165970546b458ac6abd7acd170a7ac563171" alt="Practical Guide to Test Automation in Software Testing"
Table of Contents
In the world of software development, quality is paramount. Users expect seamless experiences, and bugs can quickly derail even the most promising projects. That's why effective software testing is non-negotiable. Test automation in software testing has become an essential tool for ensuring software quality, offering significant advantages over traditional manual testing. This comprehensive guide will explore the ins and outs of test automation, from its core principles to advanced techniques. We'll cover everything from choosing the right tools to overcoming common challenges, and we'll even delve into the exciting future of AI-powered test automation. Whether you're a seasoned tester or just starting out, this guide will provide valuable insights to help you elevate your testing game.
Key Takeaways
- Prioritize the right tests for automation: Focus on automating frequently run tests, those prone to human error, and tests that require multiple data sets or configurations. This maximizes your return on investment and frees up human testers for more complex tasks.
- Select tools and frameworks strategically: Consider factors like ease of use, cross-platform compatibility, reporting capabilities, and integration with your existing development pipeline. The right tools streamline your workflow and improve testing efficiency.
- Balance automation with human expertise: Automated tests excel at repetitive tasks, but human testers bring invaluable skills in exploratory testing, usability evaluation, and understanding complex user scenarios. Combine both for a comprehensive approach to software quality.
What is Test Automation?
Test automation uses software separate from the software being tested to control the execution of tests and the comparison of actual outcomes with predicted outcomes. It's like having a robot do the repetitive work of manually checking software, freeing up human testers for more strategic tasks. Think of it as creating a set of instructions (scripts) that a computer can follow precisely, ensuring consistent and thorough testing every time. This is crucial in modern software development, especially with Agile and DevOps practices where rapid releases are common.
Key Components and Principles
Test automation involves several key components:
- Test scripts: These are the coded instructions that dictate the steps of a test. They define the actions to be performed, the expected results, and how to evaluate the software's behavior.
- Test framework: This provides a structure and set of guidelines for organizing and running tests. It includes libraries, tools, and conventions that streamline the automation process.
- Test data: This is the input used to exercise the software during testing. It can include sample data, boundary conditions, and invalid inputs to ensure comprehensive coverage.
- Test environment: This is the dedicated setup where tests are executed. It mimics the real-world environment in which the software will operate.
- Reporting and analysis: Test automation tools generate reports that summarize test results, identify defects, and track progress over time.
Automated vs. Manual Testing
While both automated and manual testing are important for software quality assurance, they have distinct characteristics:
- Speed and Efficiency: Automated tests run much faster than manual tests, allowing for quicker feedback and faster releases. Imagine manually testing hundreds of scenarios after every code change—automation makes this feasible.
- Accuracy and Reliability: Automated tests eliminate human error, providing consistent and reliable results. Computers follow instructions precisely, reducing the risk of overlooked defects.
- Cost-Effectiveness: While there's an initial investment in setting up automation, it saves money long-term by reducing manual effort. Think of it as an upfront investment that pays off over time.
- Test Coverage: Automation enables broader test coverage by allowing for more tests across different environments and configurations. This helps identify edge cases and potential issues that might be missed during manual testing. Manual testing, however, remains essential for exploratory testing, usability testing, and scenarios that require human judgment. It's about finding the right balance between automation and manual effort for optimal software quality. For a deeper dive into manual testing, check out this resource.
Benefits of Test Automation
Automating your software testing offers several key advantages that can significantly improve software quality and development velocity. Let's explore some of the core benefits:
Increased Efficiency and Speed
Automated testing executes tests much faster than manual testing. A machine can perform the same repetitive task hundreds of times without getting tired or making mistakes. This speed allows you to run tests more frequently, accelerating the feedback loop and enabling quicker identification and resolution of issues. This also means you can release software updates more rapidly, keeping your product competitive and meeting market demands. Automated tools can run entire test suites in minutes—something that could take days manually—freeing up your team to focus on more complex or creative tasks.
Improved Accuracy and Reliability
Humans are prone to errors, especially when performing repetitive tasks. Automated tests eliminate this human error factor, leading to more accurate and reliable results. Computers follow predefined scripts precisely, ensuring consistency across every test run. This precision is crucial for catching subtle bugs that might be missed during manual testing. With automated testing, you can trust that the results are objective and consistent, providing a solid foundation for assessing software quality. This improved accuracy also reduces the risk of releasing software with critical defects, protecting your brand reputation and user experience.
Cost Savings and ROI
While there's an initial investment in setting up test automation, it ultimately leads to significant cost savings. Finding and fixing bugs early in the development cycle is considerably cheaper than addressing them after release. Automated testing helps identify these bugs early on, reducing the time and resources spent on later debugging. Moreover, automated tests can be reused across multiple projects and releases, further maximizing your return on investment. By reducing the need for extensive manual testing, you can optimize your team's resources and allocate budget to other critical areas of development. For more information on pricing and ROI, visit our pricing page.
Broader Test Coverage and Consistency
Automated testing allows you to achieve broader test coverage than manual testing. You can run a larger number of tests across different configurations, platforms, and devices, ensuring your software functions correctly in diverse environments. This comprehensive testing approach helps identify potential issues that might not be apparent through limited manual testing. Automated tests also ensure consistency in testing procedures, as every test is executed the same way every time. This consistency is essential for reliable results and helps identify regressions quickly. With broader coverage, you can release software with greater confidence, knowing it has been thoroughly vetted across a wide range of scenarios. To learn more about how MuukTest achieves comprehensive test coverage, visit our services page.
Which Tests to Automate
Deciding which tests to automate is key to a successful test automation strategy. While automating everything might sound appealing, it's not always practical or efficient. Focus on tests that offer the greatest return on investment and significantly improve your testing process.
Regression and Smoke Testing
Regression testing ensures that new code changes haven't introduced bugs into existing functionality. Given how frequently these tests run, especially after every code update, automating them is a smart move. This speeds up the feedback loop and allows developers to catch issues quickly. Similarly, smoke testing—a quick check of core application functionality—benefits greatly from automation. Automating smoke tests provides rapid feedback on the stability of each build, allowing teams to address critical problems early on.
Performance and Load Testing
Performance testing assesses how an application behaves under different conditions, while load testing focuses specifically on performance under expected user loads. Automating these tests is crucial for consistent and repeatable results. By automating performance and load tests, teams can identify bottlenecks and performance issues early in the development cycle, preventing costly fixes later. This also allows for more efficient use of resources, as automated tests can run overnight or during off-peak hours.
Data-Driven and API Testing
Data-driven testing, where the same tests run with various inputs, is a perfect candidate for automation. This approach maximizes test coverage with minimal manual effort. API testing, which validates the functionality, reliability, and performance of APIs, is another area ripe for automation. Because API tests can run without a user interface, automation makes them faster and more efficient, allowing for quicker feedback on API changes and integrations.
Choosing Test Automation Tools and Frameworks
Picking the right test automation tools and frameworks is crucial for successful software testing. A well-chosen toolset streamlines your testing process, improves accuracy, and saves you time and money. This section helps you understand the key factors to consider when making your decision.
Key Tool Selection Factors
When evaluating test automation tools, consider these practical factors:
- Ease of Use: How easy is the tool to learn and use for your team? A user-friendly interface and clear documentation can significantly reduce the learning curve and speed up implementation. If your team is already familiar with a particular scripting language, choosing a tool that supports that language can be beneficial.
- Cross-Platform Compatibility: Does the tool support the platforms and environments relevant to your software? Ensure the tool works seamlessly across different operating systems, browsers, and devices your target users might use. This ensures comprehensive test coverage.
- Reporting and Analysis: Clear and comprehensive test results are essential for quick identification and resolution of issues. Look for tools that provide detailed reports, logs, and visualizations of test execution and results. Easy-to-understand reports help your team quickly pinpoint failures and analyze trends. Consider tools that integrate with popular reporting and dashboarding solutions.
- Flexibility and Scalability: Can the tool handle different types of tests, from unit and integration tests to end-to-end and performance tests? A versatile tool can adapt to your evolving testing needs and scale as your software grows. Consider whether the tool can integrate with other tools in your development pipeline, such as CI/CD systems.
- Cost: Evaluate the total cost of ownership, including licensing fees, maintenance, and support. Balance the cost with the features and benefits the tool offers. Open-source tools can be a cost-effective option, but consider the potential for increased setup and maintenance effort. Factor in the cost of training your team on the new tool.
- Test Maintenance: How resistant are the tests created by the tool to changes in the application under test? Frequent updates to your software shouldn't require extensive rewrites of your test scripts. Look for tools that offer features like robust object recognition and intelligent waiting mechanisms to minimize test maintenance. A tool that minimizes test maintenance frees up your team to focus on other critical tasks.
- Community Support and Documentation: A strong community and comprehensive documentation can be invaluable when you encounter challenges. Active forums, tutorials, and readily available support can help you troubleshoot issues and get the most out of your chosen tool. Look for tools with active communities and readily available support resources.
Popular Automation Tools and Features
Several popular automation tools cater to various testing needs. Here are a few examples:
- Selenium: A widely used open-source framework for web testing, Selenium supports multiple browsers and programming languages. Its flexibility and extensive community support make it a popular choice. Check out the official Selenium website for more information.
- Appium: Designed for mobile testing, Appium allows you to automate tests for iOS and Android apps. It supports multiple programming languages and integrates with various testing frameworks. The Appium documentation provides a comprehensive overview of its features and capabilities.
- Cypress: A modern JavaScript-based end-to-end testing framework, Cypress offers a developer-friendly experience with features like time travel debugging and automatic waiting. Visit the Cypress website to learn more.
- JUnit and TestNG: These popular Java testing frameworks provide a structure for writing and running unit tests. They offer features like annotations, assertions, and test runners. JUnit and TestNG both have extensive documentation and active communities.
- API Testing Tools (e.g., SoapUI, Postman): These tools specialize in testing APIs and web services. They allow you to create and execute various API requests, validate responses, and automate API testing workflows.
- Behavior-Driven Development (BDD) Tools (e.g., Cucumber): BDD tools bridge the gap between technical and non-technical stakeholders by using a natural language format for defining test scenarios. This collaborative approach helps ensure everyone understands the testing process.
Remember, the "best" tool depends on your specific project requirements and team expertise. Carefully consider the factors discussed above and evaluate several options before making a decision. Don't hesitate to experiment with different tools to find the one that best fits your needs. MuukTest's expertise can guide you through this process, ensuring you select the most effective tools and frameworks for your test automation strategy. Learn more about our test automation services.
Best Practices for Test Automation
Effective test automation requires careful planning and execution. These best practices will help you build a scalable and maintainable automated testing framework.
Build a Robust Automation Strategy
Start with a solid test automation plan. Define your goals, scope, and the key metrics you'll use to measure success. Consider which tests provide the most value when automated and which are better suited for manual testing. Choosing the right automation tools is crucial for your project. Research different options and select those that align with your project's technical requirements and your team's expertise. The goal is to find a balance between automated and manual testing to ensure comprehensive coverage and efficient use of resources.
Create Modular and Reusable Test Scripts
One of the biggest advantages of automation is the ability to reuse test scripts. Design your scripts with modularity in mind. This approach makes them adaptable and easier to maintain. Focus on automating repetitive tests, tests requiring multiple devices, or those difficult to perform manually. A well-structured, modular framework ensures your test scripts are reusable across different test cases, reducing redundancy and improving maintainability.
Integrate with CI/CD Pipelines
Integrating automated tests into your CI/CD pipeline is essential for continuous testing. This practice allows tests to run automatically whenever new code is added or changes are made. This rapid feedback loop helps identify and address bugs early in the development cycle, speeding up development and improving software quality. Seamless integration ensures that testing is a consistent and integral part of your development workflow.
Monitor and Improve Continuously
Test automation isn't a set-it-and-forget-it task. Regularly monitor the results of your automated tests, tracking key metrics like the number of bugs found and test execution time. Use tools that allow you to schedule tests automatically and generate reports to gain insights into your testing process. As your software evolves, ensure your tests stay relevant and accurate by regularly reviewing and updating them. This keeps them aligned with changes in functionality and user workflows. Continuous monitoring and improvement are key to maximizing the effectiveness of your test automation efforts. Learn more about relevant test automation metrics and best practices for tracking and optimizing your automated testing strategy.
Overcoming Test Automation Challenges
Getting started with test automation can feel like a steep learning curve, but addressing common challenges head-on makes the process smoother. Let's break down some key hurdles and how to overcome them.
Initial Setup and Investment
Implementing test automation requires an upfront investment in tools, infrastructure, and training. Selecting the right tools for your needs is crucial, as is ensuring your team has the necessary skills. MuukTest's test automation services can help streamline setup and reduce the initial learning curve. Consider this investment against the long-term cost savings and efficiency gains that automation offers. A strategic approach that considers these factors will set you up for success.
Maintaining and Updating Test Scripts
As your software evolves, so too should your test scripts. Keeping test scripts up-to-date can be a major challenge, especially with frequent software updates. Prioritize writing modular and reusable test scripts from the outset. This approach makes updates easier to manage and reduces the risk of your test suite becoming a bottleneck. A version control system for your scripts and regular reviews will ensure they remain aligned with your software's functionality.
Handling Complex Scenarios and Edge Cases
Automating complex test scenarios and edge cases can be tricky. It's often difficult to determine which tests should be automated, especially when dealing with intricate user interactions or unexpected inputs. Start by focusing on automating the most common user flows and gradually incorporate more complex scenarios. MuukTest can help you achieve comprehensive test coverage within a defined timeframe, ensuring even edge cases are addressed.
Managing Test Data and Environments
Efficiently managing test data and environments is essential for successful test automation. Creating and maintaining test data can be time-consuming, and ensuring consistent test environments can be complex. Explore tools that automate test data generation, reducing manual effort and ensuring data consistency. Cloud-based testing environments can simplify environment management and improve scalability. MuukTest offers scalable solutions tailored to your needs, helping you manage both data and environments effectively.
Measuring and Optimizing Test Automation Success
Once you’ve implemented automated tests, the next step is measuring their effectiveness and identifying areas for improvement. This continuous evaluation ensures your automated tests contribute meaningfully to your overall software quality goals.
Key Performance Indicators for Automation
Tracking the right metrics provides insights into the health and efficiency of your test automation efforts. Here are some key performance indicators (KPIs) to consider:
- Test Coverage: This metric measures the percentage of your application's code covered by automated tests. Higher test coverage generally indicates better risk mitigation, but aim for meaningful coverage rather than simply chasing a high number. Focus on critical functionalities and user workflows.
- Automation Execution Time: How long does it take to run your entire automated test suite? Shorter execution times allow for quicker feedback and faster release cycles. Monitor this metric to identify bottlenecks and optimize test execution speed. Services like MuukTest can significantly reduce execution time.
- Defect Detection Rate: This KPI tracks the number of defects found by automated tests. A consistently high defect detection rate suggests your tests are effective at uncovering issues. Analyze the types of defects found to refine your testing strategies. Real-time visibility into these metrics, offered by many test management platforms, helps you stay informed about the testing process.
- Test Pass/Fail Rate: While a high pass rate is desirable, it's important to analyze the reasons behind test failures. False positives (tests failing when they shouldn't) can erode trust in your automation suite. Regularly review failed tests to identify and fix underlying issues.
- Return on Investment (ROI): Ultimately, test automation should contribute to a positive ROI. This can be measured by factors like reduced testing costs, faster time to market, and improved product quality. Quantifying ROI can justify the initial investment in automation and demonstrate its value.
Strategies for Continuous Refinement
Test automation isn't a one-time setup; it requires ongoing refinement to stay effective and relevant. Here are some strategies to ensure continuous improvement:
- Regularly Review and Update Test Scripts: As your application evolves, so should your automated tests. Keep test scripts up-to-date with code changes to prevent false positives and ensure accurate testing. Address the maintenance of test scripts proactively to avoid accumulating technical debt. Consider solutions like MuukTest to help manage this.
- Prioritize Test Automation Efforts: Focus on automating tests that provide the most value. Start with critical functionalities, frequently used features, and tests that are time-consuming or difficult to perform manually. A strategic approach to test automation maximizes its impact.
- Invest in Training and Skill Development: Equipping your team with the right skills is crucial for successful test automation. Provide training on automation tools, frameworks, and best practices. If your team is new to automation, resources like MuukTest's QuickStart can be invaluable.
- Embrace Continuous Integration and Continuous Delivery (CI/CD): Integrating automated tests into your CI/CD pipeline enables automated test execution with every code change. This provides rapid feedback and helps catch issues early in the development cycle. Learn more about CI/CD pipelines and how they can benefit your team.
- Monitor and Analyze Test Results: Don't just run tests; analyze the results to identify trends, patterns, and areas for improvement. Use test management tools to track metrics, generate reports, and gain insights into your automation effectiveness. Regular monitoring helps you stay ahead of potential problems. Consider exploring the pricing and customer stories of automation services to see how they can benefit your organization.
The Future of Test Automation: AI and Machine Learning
As software development continues to evolve, the role of artificial intelligence (AI) and machine learning (ML) in test automation is becoming increasingly important. These technologies offer the potential to transform software testing, enabling greater efficiency, accuracy, and coverage. Let's explore two key areas where AI and ML are shaping the future of test automation.
AI-Powered Test Generation and Execution
One of the most promising applications of AI in test automation is the automatic generation of test cases. Traditionally, creating these has been a manual and time-consuming process, often requiring significant effort from QA teams. AI algorithms can analyze software requirements, user stories, and even code itself to automatically generate a comprehensive set of test cases, covering a wider range of scenarios and edge cases. This reduces the manual effort involved in test creation and accelerates the overall testing process. Imagine AI intelligently crafting tests, freeing up your team to focus on more strategic testing activities. This shift towards AI-driven automated testing allows software to be tested faster and more efficiently. Services like MuukTest are at the forefront of this evolution, leveraging AI to enhance test coverage and efficiency.
Predictive Analytics for Test Suite Optimization
Another exciting area where AI and ML are making an impact is test suite optimization. Predictive analytics can analyze historical test data, identify patterns, and predict which tests are most likely to fail in the future. This allows QA teams to prioritize their testing efforts, focusing on the most critical areas and reducing the time spent on tests less likely to uncover defects. By optimizing test suites based on data-driven insights, teams can improve the overall effectiveness of their testing process and ensure that the most important aspects of the software are thoroughly validated. This approach saves time and resources and helps identify potential issues earlier in the development cycle. Several industry articles discuss the growing role of AI and ML in predicting potential defects and optimizing the testing process. This predictive capability is key to achieving comprehensive test coverage efficiently, a core value proposition of MuukTest, as demonstrated on their customer page.
The Evolving Role of Human Testers
With the rise of automated testing, some might wonder about the future of human testers. The truth is, their role isn't disappearing—it's evolving. While automation excels at repetitive tasks, human intelligence and intuition remain essential for ensuring software quality. Testers are now focusing on more complex and nuanced aspects of testing, leveraging their expertise in ways that complement automation. This shift allows human testers to provide more strategic value, focusing on areas where their skills and insights are most impactful.
Focus on Complex Testing Scenarios
Automated tests are great for catching common bugs and regressions, but they can't replicate the unpredictable nature of human interaction. Think about exploratory testing, where a tester uses the software intuitively, mimicking real-world user behavior. This requires creativity, critical thinking, and a deep understanding of user experience—qualities that are uniquely human. Identifying edge cases and unusual bugs often requires a fresh perspective that automated tests might miss. Human testers also provide valuable qualitative feedback on usability and overall user satisfaction, going beyond the pass/fail results of automated checks. This focus on the human element ensures a more user-centered approach to software development.
Balancing Automation and Human Expertise
The key to successful software testing lies in finding the right balance between automation and human expertise. Automation should handle the repetitive, data-heavy tasks, freeing up human testers to focus on more complex scenarios. Think of it as a strategic partnership: automation provides efficiency and speed, while human testers provide critical thinking and nuanced insights. The decision of what tests to automate should be made carefully, prioritizing those that are frequently run, time-consuming, or prone to human error. By integrating automated and manual testing efforts, teams can leverage the strengths of both approaches, ensuring comprehensive test coverage and delivering high-quality software. This collaborative approach not only improves efficiency but also allows human testers to focus on what they do best: providing valuable insights that enhance the user experience. This balanced approach ultimately leads to better software and happier users.
Getting Started with Test Automation
Jumping into test automation can feel overwhelming, but a structured approach makes it manageable. Here’s a practical roadmap to get you started:
1. Planning Your Tests
Before writing any code, map out your testing strategy. Consider which tests offer the most value when automated. Prioritize tests that run frequently, like regression tests, or those prone to human error. A well-defined plan keeps your automation efforts focused and effective. Think about the order your tests will run and explore tools that can automate this process on a schedule. For a deeper dive into building a robust testing strategy, check out MuukTest's expert QA services.
2. Choosing the Right Tools
Selecting the right tools is crucial for successful automation. Consider factors like ease of use, cross-platform compatibility (browsers and operating systems), reporting clarity, flexibility, cost, and vendor support. The right tools will streamline your workflow and maximize your return on investment. MuukTest offers comprehensive test automation services designed to meet diverse needs and simplify this process.
3. Defining Test Steps
Clearly outlining each test step and its expected outcome is essential. This clarity forms the foundation for writing effective automated tests and ensures alignment with software requirements. Detailed test steps also make it easier to identify and troubleshoot issues during test execution.
4. Writing Test Scripts
With your test steps defined, you can begin writing the actual test scripts. This involves using a programming language or a testing framework suitable for your project. Select a language and framework that aligns with your team's skills and the technical requirements of your project.
5. Running and Checking Results
Execute your test scripts and carefully analyze the results. Identify any failures or unexpected behaviors. Thorough result analysis is key to uncovering and addressing software defects early in the development cycle.
6. Maintaining Tests
As your software evolves, so should your tests. Regularly update your test scripts to reflect changes in functionality or design. Consistent maintenance ensures your automated tests remain relevant and effective in catching regressions. For a jumpstart on implementing these steps, consider MuukTest's QuickStart program. You can also explore our pricing plans to find the best fit for your needs.
Frequently Asked Questions
What's the biggest mistake people make when starting with test automation?
Trying to automate everything at once. Start small, focus on the most critical and frequently used functionalities, and gradually expand your automated test suite. It's better to have a small, reliable set of automated tests than a large, unmanageable one full of flaky tests. Prioritize tests that are repetitive, time-consuming, or prone to human error when performed manually.
How do I choose the right test automation tools for my team?
Consider your team's existing skills and the specific needs of your project. Think about factors like programming language familiarity, platform compatibility, ease of use, reporting capabilities, and budget. Don't be afraid to experiment with a few different tools to find the best fit. If you're feeling overwhelmed, consider consulting with test automation experts for guidance.
Is it possible to achieve 100% test automation?
While it's a tempting goal, 100% test automation is rarely practical or achievable. Some tests, like exploratory testing and usability testing, inherently require human judgment and intuition. Focus on automating tests that provide the greatest return on investment and leave the more nuanced testing to human testers. Strive for a balance that leverages the strengths of both automated and manual testing.
How much does test automation cost?
The cost of test automation varies depending on factors like the tools you choose, the complexity of your software, and whether you opt for in-house expertise or outsourced services. While there's an initial investment involved, test automation often leads to long-term cost savings by reducing manual testing effort and catching bugs earlier in the development cycle. Consider the long-term benefits when evaluating the cost.
What's the role of a human tester in an increasingly automated world?
Human testers remain essential for ensuring software quality. Their role is evolving to focus on more complex testing scenarios, exploratory testing, usability testing, and providing qualitative feedback. They complement automated tests by bringing human intuition, creativity, and a deep understanding of user experience to the testing process.
Related Posts:
data:image/s3,"s3://crabby-images/4a710/4a710ed8cf65a9c7b77234d9ffb76877b9e5b10f" alt="Software Automated Testing: A Practical Guide"
Software Automated Testing: A Practical Guide
Tired of tedious manual tests and the constant worry of bugs slipping through the cracks? Software automated testing is your ticket to faster releases and higher-quality software. It's like having a...
data:image/s3,"s3://crabby-images/70f18/70f18be21daf152d1adba0cd477cc86169b8311e" alt="Test Automation Testing: Your Complete Guide"
Test Automation Testing: Your Complete Guide
Repetitive tasks can drain your team's energy and time, especially in software development. Test automation offers a powerful solution by automating repetitive testing processes, freeing up your team...
data:image/s3,"s3://crabby-images/04d93/04d93ffffecf2a083ac9bbfe4986b50c9e579f4d" alt="QA Automation Testing: Your Complete Guide"
QA Automation Testing: Your Complete Guide
Tired of tedious, repetitive testing tasks? Wish you could free up your team to focus on more strategic work? QA automation testing might be the answer. This post provides a comprehensive guide to QA...