How To Setup JUnit Environment For Your First Test

Sri Priya

Posted On: July 31, 2024

view count337873 Views

Read time18 Min Read

JUnit is a widely used unit testing framework. When combined with Selenium, it enhances the web application testing process. JUnit utilizes annotations to identify test methods and supports various assertions, test suites, and test maintenance.

To start implementing JUnit on your machine, it’s important to understand the basics of JUnit and its architecture. Additionally, you will need to know how to setup JUnit from scratch.

What Is JUnit?

JUnit is a popular framework for automating unit testing in Java. It follows the principle of “Testing first, then coding,” which means you write tests before implementing the code that the tests will validate.

With this framework, you create test cases to perform unit testing. A unit test case is a block of code that verifies whether the program logic is functioning as expected.

Here are the reasons why JUnit is important for unit testing:

  • Improves Code Quality: It helps make code more readable, stable, and error-free.
  • Early Bug Detection: It helps identify bugs early in development, increasing application stability.
  • Annotations and Assertions: It provides annotations, test methods, hooks, and assertions to verify expected results.
  • Test Runners: It includes test runners to execute tests and report results.
  • Automated Testing: Its tests run automatically and provide feedback on whether the code behaves as expected. Test results are often displayed in a progress bar or similar visual format.
Info Note

Run web app testing using the JUnit framework with over 3000+ browser and OS combinations. Try LambdaTest Today!

 

Now that you understand the basics of JUnit and its importance for unit testing let’s learn about its working architecture.

JUnit 5 Architecture

JUnit 5 is organized into several modules, divided across three distinct sub-projects, each serving a specific purpose.

junit 5 architecture

JUnit Platform

JUnit Platform is the foundational component for testing frameworks on the Java Virtual Machine (JVM). It provides a standard interface for test discovery and execution, supporting various build tools, IDEs, and test frameworks. It includes the TestEngine API, which allows for creating custom test engines and integrating third-party testing libraries. This architecture enables seamless execution and management of tests across different testing frameworks.

JUnit Jupiter

JUnit Jupiter is the new extension of JUnit. It consists of new annotations and libraries of JUnit 5 to use in the test classes by enhancing capabilities beyond those in JUnit 4. To be more clear, JUnit Jupiter consists of two parts: Jupiter API and Jupiter Engine.

  • Jupiter API: It provides a new set of annotations and assertions.
  • Jupiter Engine: It helps execute tests written with the Jupiter API.

Junit Vintage

JUnit Vintage provides a Test Engine to run JUnit 4 and JUnit 3 tests, allowing users to run legacy and new tests written with JUnit 5. JUnit Vintage is a supporting library within the JUnit 5 ecosystem to ensure a smooth transition from earlier versions of JUnit.

Follow the video below to learn more about JUnit architecture and how it is better than JUnit 4.

Subscribe to the LambdaTest YouTube Channel to stay updated on video tutorials related to Selenium Java, JUnit testing, and more.

Let’s learn how to setup JUnit further, including the necessary libraries and components for effective use.

How To Install and Setup JUnit?

Here, you will get a step-by-step guide on downloading and setting up JUnit on your machine so you can use it effectively. To do so, let’s start with the pre-requisites:

Installing Java

Installing the Java Development Kit (JDK) is essential to setup JUnit for automation testing. This JDK enables you to code and run Java programs. It is recommended that you install the latest version.

Below are the steps to guide you on installing Java on Windows.

  1. Go to the Java SE (Standard Edition) page and click JDK Download.
  2. Accept the license agreement to download the JDK executable file.
  3. Double-click on the installer executable to begin the installation process. After installation, the JDK will be located in Program Files > Java > JDK-22 (or a similar directory, depending on your installed version).
  4. Upon installation of Java, you must append the installation location to the environment variables PATH and CLASSPATH.
  5. Search for Environment Variables in your system and select Edit the system environment variables.
  6. Click the Advanced tab in the System Properties window, then click the Environment Variables… button.
  7. Under System Variables, click New.
  8. Under the Variable name, enter JAVA_HOME, and for the Variable value, enter the path where your JDK is stored. Click the OK button to save the entries.
  9. The last step is to verify if the installation of Java on the machine was successful. To do so, run the command java version to verify it.

You have successfully setup Java on your machine by following the steps above. Next, let’s proceed to setup the JUnit environment variable.

Setting JUnit Environment Variable

Here, you will learn two key aspects: installing JUnit and setting up its environment variables.

Follow the steps below to complete the setup of JUnit on your machine, including downloading and installing JUnit 5.

  1. Go to the JUnit 5 releases page on Maven Central or the JUnit official website.
  2. Download the latest version of JUnit 5. You’ll typically need the following JAR files:
    • junit-jupiter-api
    • junit-jupiter-engine
    • junit-platform-launcher

    You can add JUnit 5 to your project using a build tool like Maven or Gradle, which will handle your dependencies.

  3. Click on junit.jar to redirect to the Maven Central repository, where you can download the JUnit jar file.
  4. In the Maven Central Repository, click on the latest version of the JUnit framework (recommended latest).
  5. This will open a page where you can download the JUnit JAR file and view options to download the dependencies for inclusion in pom.xml. Since we are manually downloading the JUnit JAR, you must include this JAR file in your pom.xml.

    Alternatively, you can download the JUnit JAR file directly from the Maven repository using this JAR file and save the JUnit JAR file in a designated location, such as C:\JUnit.

  6. Download the Hamcrest (v2.2) JAR file from the Maven repository. The Hamcrest core jar file is now obsolete. Instead, a single Hamcrest jar file has to be downloaded so that you can execute the JUnit tests in Eclipse, IntelliJ, and on the command line.
  7. So far, we have downloaded two jar files (JUnit and Hamcrest) on our system. The files are placed in the C:\JUnit folder directory.

Now that you have completed the setup for JUnit along with the required libraries, the next step is to configure the necessary environment variables for accessing the JUnit framework.

To setup the JUnit environment variable on your machine, follow the same steps you used for setting up the Java environment variable.

Below are the steps for setting up JUnit environment variables.

  1. Search for Environment Variables on Windows.
  2. In the System Properties window, click on Environment Variables…
  3. Under the System Variables section, click New.
  4. Enter JUNIT_HOME for the Variable name and the path where JUnit is stored for the Variable value.
  5. Click OK to save the new environment variable.

Great, you have completed the setup of JUnit on your machine. Next, learn to configure and use JUnit in an IDE like IntelliJ.

How To Use JUnit With IntelliJ IDEA?

IntelliJ IDEA is a popular cross-platform Integrated Development Environment (IDE) developed by JetBrains. It supports Java, Kotlin, Scala, Groovy, and various other languages through plugins, including PHP, Python, Ruby, and JavaScript. IntelliJ IDEA is suitable for various development needs and is available in an Apache-licensed Community Edition and a proprietary Commercial Edition.

Setting IntelliJ IDEA Environment

Once you’ve completed the setup of JUnit on your machine, you can leverage IntelliJ IDEA to write and manage more complex test code. This IDE simplifies using the JUnit framework, allowing you to write, execute, and manage your tests efficiently.

To get started, follow these steps for the setup of JUnit in IntelliJ:

  1. Create a new Maven project in IntelliJ and select the project SDK.
  2. Name your project JUnit Demo.
  3. If multiple Java SDK versions are installed on your system, you can choose the desired Java SDK for your project.
  4. Right-click on your project and select Open Module Settings.
  5. Under Project Settings, click on Project.
  6. Select the Java SDK version “22” in the Project SDK dropdown.
  7. Click OK to apply the changes.
  8. Once the project structure is ready, you can create a new package in \src\test\java.
  9. You can name the package com.test.junitdemo.
  10. Right-click on the newly created package (e.g., com.test.junitdemo) and select New > Java Class to create a new Java class.

Alternatively, If you’re using Maven or Gradle, add JUnit dependencies to your pom.xml or build.gradle file respectively.

For Maven:

For Gradle:

Note: If not using a build tool, download the JUnit JAR files and add them to your project’s classpath.

Creating Your First JUnit Test

After completing the setup of JUnit, it is time to create your first test. Writing a basic code will help you understand how JUnit works and validate that your setup is correct.

The below class has a method that converts Fahrenheit to Celsius.

Now, let us write the simple JUnit test class to test the conversion() in Class 1.

The JUnit annotation @Test tells JUnit that the public void method it is attached to can be run as a test case.

We split the JUnit test class into three parts: Given, When, and Then.

  • Given: you can create and initialize a new class instance under test.
  • When: you can setup the variables that need to be passed when calling the method under test. If the method returns a value, it must be captured in a variable for assertion.
  • Then: you can assert that the actual value matches the expected value using the assertEquals(expected, actual, delta) method.
  • Here:

    • expected is the value specified for comparison.
    • actual is the value returned by the method being tested.
    • delta is the margin of error for the comparison for validating floating-point values.

To learn more about JUnit assertion, watch the video below and get detailed insights.

Setting JUnit in IntelliJ IDEA

There are two ways to setup JUnit on IntelliJ IDEA:

  • Adding local dependencies (to add JUnit, Hamcrest, and other relevant dependencies)
  • You can specify the paths to local dependencies (e.g., JUnit and Hamcrest) in the pom.xml file. If you have used pom.xml in Eclipse, you can use the same file in IntelliJ IDEA without any modifications.

    Here is an example snippet from pom.xml showing how to include local dependencies:

    Double-click on any JUnit import statement to verify that the local dependencies are correctly included (e.g., import org.junit.AfterClass;). This will confirm if the local dependencies are fulfilled as specified in the pom.xml.

  • Installing JUnit jar in IntelliJ as External Jar
  • If you prefer not to use pom.xml, add local dependencies through the IntelliJ IDEA GUI. Dependencies are libraries on which the module depends, such as JUnit and Hamcrest.

    Dependencies can be added at three levels in IntelliJ IDEA:

    • Global – Available for many projects
    • Module – Available for a specific module
    • Project – Available for all modules within a project

    To install JUnit and Hamcrest JAR files as external libraries at the ‘Project Level’:

    1. Right-click on the project or go to File > Project Structure in the menu and select Open Module Settings.
    2. In the Project Settings window, select Libraries. Click the + button and choose Java.
    3. Navigate to the path containing the JUnit and Hamcrest JAR files. Select these files and click OK.
    4. The JAR files will be added as External Libraries to the project.
    5. To verify the successful addition of External Libraries, double-click on any JUnit import statement (e.g., import org.junit.AfterClass;). You will see that it refers to the JUnit JAR included as an External Library in the project.

    With the above steps, you have completed the setup of JUnit in IntelliJ. Now, let’s learn how to execute your JUnit tests within the IntelliJ platform.

    Executing JUnit Tests in IntelliJ IDEA

    To run JUnit tests in IntelliJ IDEA, follow the below steps:

    1. Right-click on the project and select Run ‘All Tests.’
    2. You can also run JUnit tests by right-clicking a particular test (e.g., JUnitDemo) and clicking Run ‘TestName’ (e.g., Run JUnitDemoClass).

    The execution snapshot below shows that the test was successfully executed.
    executing junit tests in intellij idea

    JUnit 5 supports parallel execution of tests, which speeds up the execution of the test suite when there are a large number of tests. There are two ways to achieve parallel execution in JUnit 5: at the class and method levels. Below, you can see how to configure parallel execution for both approaches.

    • Class level: To achieve parallel execution at the class level, you must set the properties below in the junit-platform.properties file.
    • Method Level: To run specific test methods in parallel within the same class, apply the @Execution annotation at the method level.
    • However, with parallel execution, managing test environments can become challenging. You can use a cloud-based testing platform like LambdaTest to overcome such a challenge.

      LambdaTest is an AI-powered test execution platform that lets you run manual and automated tests using one or more testing frameworks in parallel over 3000+ real devices, browsers, and OS combinations.

      Let us execute a small parallel test to ensure the search functionality works correctly when searching for an iPhone.

      Test Scenario:

      1. Open the browser and navigate to LambdaTest eCommerce Playground.
      2. Maximize the browser window.
      3. Locate the search input field and enter “iPhone.”
      4. Click on the search button.
      5. Verify that the page title is “Search iphone.”

      Expected Result:

      The page title should be “Search iphone”, indicating that the search functionality works as expected. This test serves as a redundant check to ensure consistency.

      Below is the code demonstrating how to implement the LambdaTest capabilities and your username and access key.

      github

      To use LambdaTest to perform parallel testing, follow the steps below.

      1. Create an account on the LambdaTest platform.
      2. Get your username and access key from the LambdaTest Profile > Account Settings > Password & Security tab. These details are required for you to initiate your test on the LambdaTest platform.
      3. You also need to get the capabilities. These capabilities allow you to setup your test details, such as the platform you want to run your test, the browser and its version, and the name of your tests. LambdaTest Capabilities Generator is core to the process and helps bridge the gap between your local test script and executing it on a cloud platform.
      4. lambdatest parallel testing steps

      5. Update the desired capabilities in the above code and run the test.

      Result:

      You can view the execution results on the LambdaTest platform. To do this, navigate to the Automation menu on the left side and click on Web Automation.

      execution results on the lambdatest platform in web automation menu

      Note: JUnit 5 uses a dynamic number thread count by default based on the availability of processors. You can limit the maximum number of threads by setting the following:

      Conclusion

      JUnit is one of the popular open-source test frameworks used for unit testing with Java. When using JUnit, you can add the dependencies dynamically using Maven or add the respective dependencies as ‘local dependencies’ (or External Libraries).

      JUnit can be used with a local Selenium Grid and a cloud-based Selenium Grid like LambdaTest. JUnit helps to write unit tests to find and fix bugs in the early stage of development. It also helps accelerate the development and deliver error-free software.

      Frequently Asked Questions (FAQs)

      How do I setup a JUnit test?

      You must create a separate .java file to setup the JUnit test. It should be in the same project that will test one of your existing classes.

      1. Right-click the class you want to test in the Package Explorer area on the left side of the Eclipse window.
      2. Click New → JUnit Test Case. This will open a dialog box to help you create your test case.

      What is a JUnit Test?

      A JUnit Test is a Java test that uses the JUnit Framework to ensure the specific code units are working as expected.

      What is the need for JUnit testing?

      JUnit testing is needed to find the bugs in the early stage of development, which increases code readability. It also makes the source code more readable and error-free.

      What are the annotations present on JUnit 5?

      @BeforeAll: runs before all test methods in the current class.
      @AfterAll: runs after all test methods in the current class.
      @BeforeEach: runs before each test method.
      @AfterEach: runs after each test method.
      @Disable: disables a test class or a method.
      @Tag: tags the test methods such as Smoke, Regression, Critical, etc.
      @Nested: annotated class is a nested, non-static test class.
      @DisplayName: declares a custom display name for a test class or method.
      @ExtendWith: it is used to register custom extensions.
      @TestFactory: declares that the method is a test factory for dynamic testing.

Author Profile Author Profile Author Profile

Author’s Profile

Sri Priya

An ISTQB certified tester with primary focus on Software Quality and making sure that Software is Bug free. She has a strong background in Testing Tools, API testing , Linux OS , UI and Backend Automation testing. I will enjoy to work in team and learning from others, across all areas of business and technologies. I love to share my knowledge and write about latest technology stacks.

Blogs: 4



linkedintwitter

Test Your Web Or Mobile Apps On 3000+ Browsers

Signup for free