Simple Unit Test তৈরি এবং চালানো

JUnit এর মৌলিক ধারণা - জেইউনিট (JUnit) - Java Technologies

239

JUnit হল একটি জনপ্রিয় টেস্ট ফ্রেমওয়ার্ক যা Java প্রোগ্রামিং ভাষায় ইউনিট টেস্টিং পরিচালনা করতে ব্যবহৃত হয়। এটি ডেভেলপারদের তাদের কোডের ছোট ছোট অংশ পরীক্ষা করার সুযোগ দেয়, যাতে কোনো ভুল বা ত্রুটি সহজেই চিহ্নিত করা যায়। JUnit দিয়ে টেস্ট লিখা এবং চালানো খুবই সহজ, এবং এটি কোডের গুণমান এবং নির্ভরযোগ্যতা নিশ্চিত করতে সাহায্য করে।

এই টিউটোরিয়ালে আমরা একটি JUnit টেস্ট তৈরি এবং চালানোর প্রক্রিয়া আলোচনা করব।


১. JUnit ডিপেনডেন্সি কনফিগারেশন

প্রথমে আপনাকে JUnit লাইব্রেরি আপনার প্রোজেক্টে অন্তর্ভুক্ত করতে হবে। Maven বা Gradle ব্যবহার করলে, আপনাকে JUnit এর ডিপেনডেন্সি আপনার প্রকল্পের pom.xml (Maven) বা build.gradle (Gradle) ফাইলে যোগ করতে হবে।

Maven Dependency:

<dependencies>
    <!-- JUnit Dependency for Unit Testing -->
    <dependency>
        <groupId>org.junit.jupiter</groupId>
        <artifactId>junit-jupiter-api</artifactId>
        <version>5.7.2</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>org.junit.jupiter</groupId>
        <artifactId>junit-jupiter-engine</artifactId>
        <version>5.7.2</version>
        <scope>test</scope>
    </dependency>
</dependencies>

Gradle Dependency:

dependencies {
    // JUnit Dependency for Unit Testing
    testImplementation 'org.junit.jupiter:junit-jupiter-api:5.7.2'
    testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.7.2'
}

এখানে JUnit Jupiter ব্যবহৃত হচ্ছে, যা JUnit 5 এর জন্য ব্যবহৃত একটি নতুন API।


২. JUnit টেস্ট কেস তৈরি করা

JUnit টেস্ট কেস তৈরি করার জন্য, আপনাকে সাধারণত @Test অ্যানোটেশন ব্যবহার করতে হয়। নিচে একটি সাধারণ টেস্ট কেসের উদাহরণ দেওয়া হলো:

উদাহরণ: Basic Unit Test

ধরা যাক, আপনার কাছে একটি Calculator ক্লাস আছে যা দুটি সংখ্যা যোগ করতে সক্ষম:

public class Calculator {
    public int add(int a, int b) {
        return a + b;
    }
}

এখন, Calculator ক্লাসের add মেথডটি টেস্ট করার জন্য একটি JUnit টেস্ট কেস তৈরি করা হবে।

CalculatorTest.java (JUnit Test)

import org.junit.jupiter.api.Test;
import static org.junit.jupiter.api.Assertions.assertEquals;

public class CalculatorTest {

    @Test
    public void testAdd() {
        Calculator calculator = new Calculator();
        int result = calculator.add(5, 3);
        // Assert that the result is correct
        assertEquals(8, result, "5 + 3 should equal 8");
    }
}

এখানে:

  • @Test: testAdd() মেথডটি একটি টেস্ট কেস হিসেবে চিহ্নিত করা হচ্ছে।
  • assertEquals(expected, actual, message): এটি টেস্টের ফলাফল যাচাই করে। এখানে, expected হল আপনার প্রত্যাশিত আউটপুট এবং actual হল সেই আউটপুট যা মেথড প্রদান করবে।

৩. JUnit টেস্ট চালানো

IntelliJ IDEA তে:

  1. JUnit টেস্ট চালানো: আপনার টেস্ট ফাইলটি খুলুন এবং Run বোতামে ক্লিক করুন (বা Ctrl + Shift + F10 ব্যবহার করুন)। IntelliJ IDEA স্বয়ংক্রিয়ভাবে আপনার টেস্টটি চালাবে এবং আউটপুট কনসোলে দেখাবে।
  2. Test Result: যদি টেস্ট সফল হয়, তবে এটি সবুজ হয়ে যাবে এবং যদি কোনো সমস্যা হয়, তবে এটি লাল হয়ে যাবে এবং ত্রুটি বার্তা দেখাবে।

Eclipse তে:

  1. JUnit টেস্ট চালানো: টেস্ট ক্লাসের উপর ডান ক্লিক করুন এবং Run As > JUnit Test নির্বাচন করুন।
  2. Test Result: টেস্ট রান করার পর, Eclipse এর নিচে JUnit ভিউতে ফলাফল দেখতে পারবেন। সফল টেস্ট সবুজ এবং ব্যর্থ টেস্ট লাল হবে।

৪. JUnit এর আরও কিছু গুরুত্বপূর্ণ ফিচার

  1. @BeforeEach এবং @AfterEach: এই অ্যানোটেশনগুলি টেস্ট চালানোর আগে এবং পরে নির্দিষ্ট মেথডগুলি চালানোর জন্য ব্যবহৃত হয়।

    • @BeforeEach: প্রতিটি টেস্ট মেথডের আগে রান করে।
    • @AfterEach: প্রতিটি টেস্ট মেথডের পরে রান করে।

    উদাহরণ:

    @BeforeEach
    public void setup() {
        // Initialization code, runs before each test
    }
    
    @AfterEach
    public void cleanup() {
        // Cleanup code, runs after each test
    }
    
  2. @BeforeAll এবং @AfterAll: এই অ্যানোটেশনগুলি class-level মেথডগুলোকে রান করার জন্য ব্যবহৃত হয়, যখন আপনি একবারে ক্লাসের আগে বা পরে কোনো কোড রান করতে চান।

    উদাহরণ:

    @BeforeAll
    public static void setupBeforeClass() {
        // Initialization code, runs once before all tests
    }
    
    @AfterAll
    public static void cleanupAfterClass() {
        // Cleanup code, runs once after all tests
    }
    
  3. @Disabled: যখন আপনি কোনো টেস্ট অস্থায়ীভাবে বাদ দিতে চান, তখন আপনি এই অ্যানোটেশন ব্যবহার করতে পারেন।

    @Test
    @Disabled("Test is disabled temporarily")
    public void testDisabled() {
        // This test will not run
    }
    

৫. JUnit টেস্ট কভারেজ

JUnit ব্যবহার করে আপনি code coverage (কোড কভারেজ) পরীক্ষা করতে পারেন, যা টেস্ট করা অংশের মাধ্যমে আপনার কোড কতটুকু আচ্ছাদিত হয়েছে তা জানায়। এটি JaCoCo বা Eclim প্লাগইন ব্যবহার করে বাস্তবায়িত হতে পারে, যা আপনার টেস্ট রান করার পরে আউটপুট হিসেবে রিপোর্ট তৈরি করে।


সারাংশ

JUnit ব্যবহার করে ইউনিট টেস্ট তৈরি করা এবং চালানো সহজ এবং কার্যকরী। @Test অ্যানোটেশন ব্যবহার করে আপনি কোডের অংশগুলো পরীক্ষা করতে পারেন এবং assertEquals সহ অন্যান্য অ্যাসার্ট টেস্ট মেথড ব্যবহার করে টেস্টের ফলাফল যাচাই করতে পারেন। JUnit আপনাকে টেস্টিং এর সময় কোডের কার্যকারিতা এবং গুণমান নিশ্চিত করতে সহায়তা করে এবং এটি IntelliJ IDEA বা Eclipse তে সরাসরি রান করা যায়। JUnit টেস্টে আরও কিছু শক্তিশালী ফিচার যেমন @BeforeEach, @AfterEach, @BeforeAll, @AfterAll, এবং @Disabled রয়েছে যা টেস্ট পরিচালনায় সহায়তা করে।

C

Content added By
Promotion

Are you sure to start over?

Loading...