Friday, March 17, 2023

Tips for effective quality control practices

 Define clear quality standards: Establish clear quality standards and communicate them to the development team. This can include performance expectations, user experience, and other factors that affect software quality.

Use automated testing tools: Leverage automated testing tools to increase efficiency and reduce errors. This can include tools for functional testing, performance testing, and regression testing.

Conduct frequent code reviews: Regular code reviews help identify issues early in the development process. This can help reduce the number of defects that are introduced into the codebase.

Use test case management tools: Use a test case management tool to manage and track test cases. This can help ensure that all test cases are executed and that results are tracked and reported accurately.

Perform exploratory testing: In addition to scripted testing, incorporate exploratory testing to identify issues that may not be caught by traditional test cases. This can help identify usability issues and other defects that may impact user experience.

Use performance monitoring tools: Use performance monitoring tools to identify performance issues in real-time. This can help reduce the impact of performance issues on end-users.

Develop a strong feedback loop: Establish a strong feedback loop between the development and testing teams. This can help identify issues early and ensure that all issues are addressed in a timely manner.

By implementing these tips, software testers can help ensure that software is of high quality and meets the needs of end-users.

Sunday, August 14, 2022

Environment setup FOR JAVA Automation Testing

Before starting the JAVA basic for automation testing, we need to do first Environment setup for automation testing as below:

  •     JDK (java development kit)
  •     Eclipse IDE
  •     Maven (build/dependency management tool)

follow the instructions as per the environment set up for Java/JDK, Eclipse IDE and Maven

Tools, Versions & URLs:

Java SE Development Kit 8u291

https://www.oracle.com/uk/java/technologies/javase/javase-jdk8-downloads.html 

Eclipse IDE for Java Developers - Version 2020-12 (4.18)

https://www.eclipse.org/downloads/packages/release/2020-12/r 

Apache Maven 3.8.1

https://maven.apache.org/download.cgi

Configure Java:

Environment variable is essentially run third party tool like Maven. 

In order to set the variable, right click on system, go to properties, Advance system settings, Environment variable, New system variable there mention variable name (java_home) and value (jdk path). 

Maven Setup:

Maven is open source tool and developed by Apache. Download the Maven package, extract it. We need to add bin folder with the Maven command and in relation to the path. for that right click on system, go to properties, Advance system settings, Go to environment variable, New variable system, there mention variable name (MVN_Home) and value (apache path) and configure the path. 

Once your Maven setup is done, make sure to close all the open existing command prompt and open the new instance and run the below query in command prompt:

 >mvn -version (provides you the maven and java version version details)

Maven_Project
 >echo %MVN_HOME% (Provides details that it pointing to correct directory)

Eclipse Setup:

Download the eclipse package, extract it and there we are able to see eclipse icon, double click and it will open eclipse.

In Eclipse, in latest version we can see the Maven is inbuild, however if you do not find it then go to google and enter 'maven eclipse plugin' and go to eclipse.org site and there go to download version. Copy the laetst version link and paste it on Eclipse available software pop up screen (include the Maven Integration for Eclipse) and install. In order to check that the Maven installation successful, select New project and there you will see the Maven option.

Wednesday, July 13, 2022

Karate Usage Guidelines

Karate Framework Usage Guidelines are as follows-

Project Structure

Each project is structured as follows:

- src (contains global config & js utils)

  - /main

    - /java/com/ddaqe (contains utility functions)

    - /resources (contains supporting jars and files)

  - /test

    - /java

      - /oneService (contain test runners and feature files)

        - /data (contains test data files for oneService)

      - /anotherService (contains test runners and feature files)

        - /data (contains test data files for anotherService)

Creating new tests

Project structure must be maintained.

Environment, accounts and database info are parameterized and defined in karate-config.js file.

    Each feature file:

        must be independent and atomic

        must contain:

    • Feature
    • Background (anything defined here applies to all scenarios in the feature file)
    • Scenarios and/or Scenario Outlines

    should retain consistent formatting to maintain readability: right-click a feature file > Pretty Format (or Ctrl+Shift+F)

Each scenario in a feature file must:

    • be independent of other scenarios and able to run in any order
    • be data-driven when appropriate (refer to https://github.com/intuit/karate#data-driven-tests)
    • have all data files go in '[package_name]/data' folder
    • be tagged with @smoke if it is a smoke test

When a script creates new content in the application under test, prefix the content with "qeauto-" when possible so that it can be identified for deletion later.

Example Karate scripts: https://github.com/intuit/karate/tree/master/karate-demo

Naming Folders & Files

(Refer to attached screenshot for examples) 

  • Name folders and files using lower Camel Case (Camel case starting with lowercase).
  • Name data files in lowercase with hyphen.
  • Services should be named based on Swagger doc information, so that names match. Example: for user details service, package name would be "userDetailsService".
  • Service folder must contain Regression, Smoke and Service runners. Simply replicate from existing copy.
  • Sub-folders are added under the service package for each endpoint path. Example: for /terms path, you create "userDetailsService\terms".
  • Feature files are added in the endpoint folder and names after the endpoint. Where multiple feature files are needed for one endpoint, append an underscore before extending the name. Example: "terms_IncorrectHeaders"



Naming Tests

The way test scripts are named is critical. These are used to report the test run status via scripts back to Adaptavist. The naming convention below must be followed to avoid incorrect reporting.

  • Each scenario description must be prefixed with the test case id, followed by a colon (with no spaces before the colon). Example for Adaptavist test case id IRIS-T223:

Feature: To Test Valuation API

  I want to verify the /lookup/valuation endpoint returns all valuation records.

  Background:

    * url baseUrl

    * header Authorization = auth

    * path '/lookup/valuation'

  Scenario: IRIS-T223: GET /lookup/valuation - All valuation records

    Given request ''

    When method get

    Then status 200

  • Some test cases belong to same functional areas or screens can be merged in a single automation script. In this case, the test case ids should be separated by underscore and represented in the format "ID1_ID2_ID3_...". This should be rare for API tests.
  • Larger manual test case can be split into multiple test scripts. In this case, test case ids should be represented in format "ID_1, ID_2, ...". This should be rare for API tests.

NOTE:

You cannot mix #2 and #3.

Naming Variables

Within feature files, name variables in all lowercase with underscore as the word separator. Example "project_url" instead of "projectUrl".

Setting up reusable features

When a set of steps needs to be repeated in multiple scripts, create reusable scenarios:

  • Create a reusable feature file in the applicable service package
  • Prefix filename with "common_"
  • Add the reusable scenario to this file
  • Add @ignore tag to the scenario in the file
  • Call the feature file from your test. Refer to examples in docs.

Karate Training

Understanding REST

Great introduction article - https://www.smashingmagazine.com/2018/01/understanding-using-rest-api/

API testing is done with the following tools:

Postman for exploratory testing

Karate for automation

The following are public APIs that you can use to try out API testing tools. 

http://petstore.swagger.io/ 

https://jsonplaceholder.typicode.com/

https://reqres.in/

https://openweathermap.org/api

https://github.com/toddmotto/public-apis/blob/master/README.md

https://any-api.com/

Testing REST APIs

Postman

    Select one of these public APIs for your use getting started

    Install Postman

    Walk through Postman docs to get started - https://www.getpostman.com/docs/v6/

    Review your public API via Postman

Karate

    Install IDE as stated in the next section

    Review Karate readme at https://github.com/intuit/karate; walk through to understand basics

    Clone repos 

    Complete your machine set up

    Write sample tests for your public API using Karate

    Review Karate Usage Guidelines

        Cover the following items with Karate and your public API:

        Using Scenarios

        Using Scenario Outlines - https://github.com/intuit/karate#data-driven-tests

        Different types of asserts - https://github.com/intuit/karate#index > "Assert" row

        Reading in files - https://github.com/intuit/karate#reading-files

        Calling other feature files for code re-use - https://github.com/intuit/karate#calling-other-feature-files

        Using js function output in scenarios - https://github.com/intuit/karate#calling-javascript-functions

        Using Java method output in scenarios - https://github.com/intuit/karate#calling-java


I also recommend watching this video from the tool author - 

https://www.techgig.com/webinar/Karate-DSL-for-writing-web-service-API-acceptance-tests-BDD-1042


IDE Setup

    The project expects JDK 1.8 (at least jdk1.8.0_162), Maven 3.5.2 and JUnit 4.

    Install the following:

    Java Development Kit: JDK 8 (http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html)

    Apache Maven 3.5 or newer - binary zip archive (https://maven.apache.org/download.cgi)

    IDE: Eclipse IDE for Java EE Developers Oxygen or newer. NOTE: You need the Java EE Developers edition (http://www.eclipse.org/downloads/packages/)

Set JAVA and Maven environment variables: Under System variables,

    Define JAVA_HOME with the path to the JDK installation.

    For example:

    JAVA_HOME

    C:\Program Files\Java\jdk1.8.0_192

Add the following variables under Path:

    %JAVA_HOME%\bin

    <path to Maven folder>\bin

    For example: 'C:\apache-maven-3.5.2\bin'



In Eclipse, set up your workspace as follows:

    Set Maven path: Go to Window menu > Preferences > Maven > Installations, add Maven install location and set as default.

    Set JDK path: Go to Window menu > Preferences > Java > Installed JREs, add installed JDK (as Standard VM) and set as default.

    Set default Java path to the JDK: Go to Window menu > Preferences > Java > Installed JREs > Execution Environments, set 'JavaSE 1.8' to the JDK.

    JUnit comes pre-installed with Eclipse. No further configuration needed for this.

    Install the free Cucumber-Eclipse plugin. Go to Eclipse Help > Eclipse Marketplace and install the latest version. This will provide syntax-coloring for feature files.

Go to the Eclipse Preferences > Cucumber > User Settings, and enter the following Root Package Name: com.intuit.karate . This resolve an issue where you encounter "does not have a matching glue code" warnings (refer to the Cucumber-Eclipse wiki for more).

Your environment is set. Follow the Bitbucket repo readme instructions to clone and set up the project.