Skill

Ionic এর মধ্যে Testing এবং Debugging গাইড ও নোট

Mobile App Development - আয়নিক (Ionic)
380

Testing এবং Debugging Ionic অ্যাপ্লিকেশনগুলির গুরুত্বপূর্ণ অংশ, কারণ এগুলি অ্যাপের কোডের ভুল এবং সমস্যাগুলি চিহ্নিত এবং সমাধান করতে সাহায্য করে। Ionic অ্যাপ্লিকেশন টেস্টিং এবং ডিবাগিং এর জন্য কিছু শক্তিশালী টুলস এবং কৌশল রয়েছে, যা উন্নত ডেভেলপমেন্ট প্রক্রিয়া নিশ্চিত করে।

এখানে Ionic অ্যাপ্লিকেশনে Testing এবং Debugging কিভাবে করা যায় তা বিস্তারিতভাবে আলোচনা করা হয়েছে।


১. Testing in Ionic

Ionic অ্যাপে বিভিন্ন ধরনের টেস্টিং করা যায়, যেমন Unit Testing, Integration Testing, এবং End-to-End (E2E) Testing। এখানে Ionic অ্যাপ্লিকেশনের জন্য ব্যবহৃত প্রধান টেস্টিং টুলস এবং কৌশলগুলো আলোচনা করা হলো।

১.১ Unit Testing in Ionic

Unit Testing হল কোডের ছোট অংশ (যেমন ফাংশন বা মেথড) পরীক্ষা করা, যাতে নিশ্চিত হওয়া যায় যে এটি সঠিকভাবে কাজ করছে। Ionic অ্যাপে Jasmine এবং Karma ব্যবহার করে Unit Testing করা হয়। Jasmine একটি জনপ্রিয় testing framework এবং Karma একটি test runner যা ব্রাউজারে কোড চালানোর জন্য ব্যবহৃত হয়।

১.১.১ Unit Testing Setup

Ionic অ্যাপে Unit Testing সেটআপ করতে আপনাকে @angular/core এবং @angular/cli প্যাকেজগুলি ইনস্টল করতে হবে।

npm install --save-dev jasmine karma karma-jasmine karma-chrome-launcher

এখন, Ionic CLI দিয়ে একটি নতুন Ionic অ্যাপ তৈরি করলে, এটি স্বয়ংক্রিয়ভাবে Jasmine এবং Karma টেস্টিং টুলস কনফিগার করে দেয়। আপনি ionic serve চালানোর পরিবর্তে, টেস্ট চালাতে পারেন:

ionic serve --lab
১.১.২ Unit Test Example

ধরা যাক, আপনার একটি সিম্পল মেথড রয়েছে যা দুইটি সংখ্যা যোগ করে। এই মেথডের জন্য Unit Test লেখার উদাহরণ:

export class CalculatorService {
  add(a: number, b: number): number {
    return a + b;
  }
}

Unit Test এর কোড:

import { CalculatorService } from './calculator.service';

describe('CalculatorService', () => {
  let service: CalculatorService;

  beforeEach(() => {
    service = new CalculatorService();
  });

  it('should add two numbers correctly', () => {
    expect(service.add(2, 3)).toBe(5);
  });
});

এই টেস্টটি নিশ্চিত করবে যে add() মেথডটি সঠিকভাবে দুটি সংখ্যা যোগ করছে।

১.২ Integration Testing in Ionic

Integration Testing হল একাধিক কম্পোনেন্ট বা সিস্টেমের একত্রে পরীক্ষা করা। এটি নিশ্চিত করতে সহায়তা করে যে পৃথক কম্পোনেন্টগুলি একে অপরের সাথে সঠিকভাবে কাজ করছে।

Ionic অ্যাপে TestBed এবং ComponentFixture ব্যবহার করে Integration Testing করা হয়। এটি Angular-এ ব্যবহৃত পরীক্ষার অংশ এবং Ionic অ্যাপের জন্য উপযুক্ত।

১.৩ End-to-End (E2E) Testing in Ionic

End-to-End (E2E) Testing হল অ্যাপের পুরো প্রক্রিয়া পরীক্ষা করা, যাতে নিশ্চিত হওয়া যায় যে অ্যাপটি ব্যবহারকারীর পক্ষে সঠিকভাবে কাজ করছে। Ionic অ্যাপে Protractor বা Cypress ব্যবহৃত হয় E2E টেস্টিংয়ের জন্য।

১.৩.১ E2E Testing Setup with Protractor

Ionic এ Protractor দিয়ে E2E Testing চালাতে প্রথমে নিচের প্যাকেজ ইনস্টল করতে হয়:

npm install --save-dev protractor

E2E টেস্টিং চালানোর জন্য:

ionic e2e
১.৩.২ E2E Test Example
import { browser, by, element } from 'protractor';

describe('Ionic App', () => {
  it('should have the correct title', () => {
    browser.get('/');
    let title = element(by.css('ion-title')).getText();
    expect(title).toEqual('Home');
  });
});

এখানে, Protractor ব্যবহার করে আপনার অ্যাপের প্রথম পেজটি পরীক্ষা করা হচ্ছে।


২. Debugging in Ionic

Debugging হল কোডের সমস্যা চিহ্নিত এবং সমাধান করার প্রক্রিয়া। Ionic অ্যাপ্লিকেশনে Debugging করার জন্য কিছু শক্তিশালী টুলস এবং কৌশল রয়েছে, যেমন Chrome Developer Tools, Ionic DevTools, এবং Capacitor Debugging

২.১ Using Chrome Developer Tools

Ionic অ্যাপের Chrome Developer Tools দিয়ে আপনি অ্যাপের JavaScript, HTML, CSS এবং Network Requests ইত্যাদি ডিবাগ করতে পারেন।

  1. প্রথমে অ্যাপটি চালান:
ionic serve
  1. তারপরে Chrome ব্রাউজার থেকে Developer Tools খুলুন (F12 বা Ctrl+Shift+I) এবং Console, Network, Elements ট্যাবগুলি ব্যবহার করে ডিবাগ করুন।

২.২ Ionic DevTools

Ionic DevTools হল একটি Chrome Extension যা Ionic অ্যাপ্লিকেশনের জন্য বিশেষভাবে তৈরি করা হয়েছে এবং এটি আপনার অ্যাপের UI এবং পারফরম্যান্স ডিবাগ করতে সাহায্য করে।

  1. Ionic DevTools ইনস্টল করুন: Ionic DevTools Chrome Extension.
  2. Ionic DevTools চালু করলে আপনি অ্যাপের বিভিন্ন অংশের ডিবাগিং করতে পারবেন এবং performance metrics, UI debug এবং app state ইত্যাদি দেখতে পারবেন।

২.৩ Capacitor Debugging

Capacitor ব্যবহার করে Ionic অ্যাপ ডিবাগ করতে, আপনাকে Xcode (macOS এ) অথবা Android Studio (Windows/macOS/Linux এ) ব্যবহার করতে হবে।

  • Android Debugging:
    • Android Studio-তে অ্যাপ রান করুন।
    • Logcat থেকে অ্যাপের লগ দেখতে পারবেন।
  • iOS Debugging (macOS):
    • Xcode-এ অ্যাপ রান করুন।
    • Xcode Console থেকে লগ এবং ডিবাগ তথ্য দেখতে পারবেন।

২.৪ Console Logging

Ionic অ্যাপে console.log() ব্যবহার করে আপনি সহজে ভ্যালু এবং এরর মেসেজগুলো দেখতে পারেন:

console.log('This is a debug message:', value);

এটি ডেভেলপার টুলসের Console ট্যাবে আউটপুট হিসেবে প্রদর্শিত হবে।

২.৫ Remote Debugging

আপনি যদি একটি মোবাইল ডিভাইসে অ্যাপ ডিবাগ করতে চান, তবে remote debugging ব্যবহার করতে পারেন। Chrome Developer Tools বা Safari Web Inspector এর মাধ্যমে মোবাইল ডিভাইসে ডিবাগ করা সম্ভব।

  • For Android: USB debugging চালু করে Chrome এর Remote Devices ট্যাবে ডিভাইস সিলেক্ট করুন।
  • For iOS: Safari Web Inspector ব্যবহার করে iOS ডিভাইসে ডিবাগ করা যায়।

সারাংশ

  • Testing in Ionic:
    • Unit Testing: Jasmine এবং Karma ব্যবহার করে ফাংশন বা মেথড টেস্ট করা।
    • Integration Testing: অ্যাপের একাধিক কম্পোনেন্ট একত্রে কাজ করছে কিনা পরীক্ষা করা।
    • End-to-End (E2E) Testing: পুরো অ্যাপের কার্যকারিতা পরীক্ষা করা।
  • Debugging in Ionic:
    • Chrome Developer Tools: ব্রাউজারে অ্যাপের ডিবাগিং করা।
    • Ionic DevTools: Ionic অ্যাপের UI এবং পারফরম্যান্স ডিবাগ করা।
    • Capacitor Debugging: মোবাইল ডিভাইসে অ্যাপ ডিবাগ করা।
    • Console Logging: ডিবাগ তথ্য দেখতে console.log() ব্যবহার করা।

Ionic অ্যাপ্লিকেশনে Testing এবং Debugging কার্যক্রমের মাধ্যমে আপনি কোডের ভুল চিহ্নিত করতে পারেন এবং অ্যাপের কার্যকারিতা উন্নত করতে পারেন।

Content added By

Unit Testing, Integration Testing, এবং End-to-End Testing

351

Testing সফটওয়্যার ডেভেলপমেন্টের একটি অপরিহার্য অংশ। বিভিন্ন ধরনের টেস্টিং ব্যবহৃত হয় যাতে অ্যাপ্লিকেশন বা সিস্টেমের বিভিন্ন স্তরের কার্যকারিতা সঠিকভাবে কাজ করছে কিনা তা নিশ্চিত করা যায়। তিনটি প্রধান ধরনের টেস্টিং হলো Unit Testing, Integration Testing, এবং End-to-End Testing (E2E)। এগুলির প্রত্যেকটি ভিন্ন ভিন্ন স্তরে কাজ করে এবং পৃথকভাবে অ্যাপ্লিকেশনের বিভিন্ন অংশের পরীক্ষণ করে।


১. Unit Testing (ইউনিট টেস্টিং)

Unit Testing হলো একটি ছোটতম টেস্টিং প্রক্রিয়া, যেখানে একক ইউনিট বা কম্পোনেন্ট (যেমন একটি ফাংশন, মেথড, অথবা ক্লাস) পরীক্ষা করা হয়। এর উদ্দেশ্য হল কোডের ছোট ছোট অংশগুলির সঠিকতা নিশ্চিত করা। সাধারণত এটি স্বতন্ত্রভাবে নির্দিষ্ট ফাংশনালিটি বা লজিক যাচাই করে।

Unit Testing এর বৈশিষ্ট্য:

  • Isolation: প্রতিটি ইউনিট পরীক্ষা স্বতন্ত্রভাবে হয়, অর্থাৎ এটি শুধুমাত্র কোডের একটি নির্দিষ্ট অংশ (যেমন একটি ফাংশন বা মেথড) পরীক্ষা করে এবং বাইরের নির্ভরতা থেকে পৃথক থাকে।
  • Mocking: অন্য ফাংশন বা ডাটাবেসের পরিবর্তে mock objects বা stubs ব্যবহার করা হয় যাতে শুধুমাত্র টেস্ট করা ইউনিটের কার্যকারিতা পরীক্ষা করা যায়।
  • Automated: Unit testing অটোমেটিক্যালি চালানো যেতে পারে এবং সহজেই পুনরাবৃত্তি করা যায়।

Unit Testing এর উদাহরণ (JavaScript):

function add(a, b) {
  return a + b;
}

describe('add function', () => {
  it('should return the correct sum', () => {
    expect(add(2, 3)).toBe(5);
  });
});

এখানে, add() ফাংশনটিকে ইউনিট টেস্ট করা হচ্ছে, এবং expect() দিয়ে তার ফলাফল যাচাই করা হচ্ছে।

Unit Testing এর সুবিধা:

  • দ্রুত ফলাফল পাওয়া যায়।
  • কোডের ছোট ছোট অংশের সঠিকতা নিশ্চিত করা যায়।
  • ডিবাগিং এবং মেইনটেনেন্স সহজ হয়।

২. Integration Testing (ইন্টিগ্রেশন টেস্টিং)

Integration Testing হলো একাধিক ইউনিট বা মডিউলের একসাথে পরীক্ষা করা, যাতে নিশ্চিত হওয়া যায় যে তারা একে অপরের সাথে সঠিকভাবে কাজ করছে। এটি unit tests থেকে বেশি বড় স্কোপে চলে যায় এবং বিভিন্ন কম্পোনেন্টের ইন্টারঅ্যাকশন পরীক্ষা করে। সাধারণত এতে ডেটাবেস, API বা অন্যান্য সার্ভিসের সাথে যোগাযোগ করা হয়।

Integration Testing এর বৈশিষ্ট্য:

  • Multiple Components: একাধিক ইউনিট বা সিস্টেমের অংশ একসাথে পরীক্ষা করা হয়।
  • Realistic Conditions: এটি বাস্তব পরিস্থিতিতে কম্পোনেন্টগুলির কাজ কীভাবে হবে তা পরীক্ষা করে, যেমন ডাটাবেস বা নেটওয়ার্ক কলের মাধ্যমে যোগাযোগ।
  • Less isolated than Unit Tests: ইন্টিগ্রেশন টেস্টে কোডের ভিন্ন ভিন্ন অংশগুলির পারস্পরিক সম্পর্ক পরীক্ষা করা হয়।

Integration Testing এর উদাহরণ (Node.js):

const request = require('supertest');
const app = require('../app');

describe('GET /users', () => {
  it('should return a list of users', async () => {
    const response = await request(app).get('/users');
    expect(response.status).toBe(200);
    expect(response.body).toHaveLength(3);
  });
});

এখানে, GET /users API endpoint পরীক্ষা করা হচ্ছে যা ডাটাবেস থেকে ইউজারের তালিকা ফেরত পাঠায়।

Integration Testing এর সুবিধা:

  • বিভিন্ন মডিউলের ইন্টিগ্রেশন যাচাই করা যায়।
  • কোডের মধ্যে বিভিন্ন অংশের সহযোগিতার সঠিকতা নিশ্চিত করা যায়।
  • ব্যবহারকারীর জন্য কার্যকরী ফিচারগুলো একত্রে সঠিকভাবে কাজ করছে কিনা তা পরীক্ষা করা হয়।

৩. End-to-End Testing (E2E Testing) (এন্ড-টু-এন্ড টেস্টিং)

End-to-End (E2E) Testing হলো একটি পূর্ণাঙ্গ পরীক্ষা যা অ্যাপ্লিকেশনের শুরু থেকে শেষ পর্যন্ত সমস্ত ফিচার এবং ফাংশনালিটি যাচাই করে। এর উদ্দেশ্য হল পুরো সিস্টেমের কার্যকারিতা পরীক্ষা করা, যাতে নিশ্চিত হওয়া যায় যে সমস্ত মডিউল এবং কম্পোনেন্ট একসাথে সঠিকভাবে কাজ করছে। এটি সাধারণত ইউজার পাসওয়ার্ড ইনপুট করা, ডাটা সাবমিট করা, লগইন করা ইত্যাদি কাজের সম্পূর্ণ পন্থা পরীক্ষা করে।

End-to-End Testing এর বৈশিষ্ট্য:

  • Realistic User Scenarios: E2E টেস্টিং ব্যবহারকারীর অভিজ্ঞতা অনুসরণ করে এবং অ্যাপ্লিকেশনটি বাস্তব ব্যবহারের মতো পরীক্ষা করে।
  • Full Application Flow: পুরো অ্যাপ্লিকেশনের প্রক্রিয়া পরীক্ষা করা হয়।
  • Tools: বিভিন্ন টুল যেমন Cypress, Selenium, বা Protractor ব্যবহার করা হয়।

E2E Testing এর উদাহরণ (Cypress):

describe('Login Test', () => {
  it('should log in the user successfully', () => {
    cy.visit('https://example.com');
    cy.get('input[name="username"]').type('user123');
    cy.get('input[name="password"]').type('password123');
    cy.get('button[type="submit"]').click();
    cy.url().should('include', '/dashboard');
  });
});

এখানে, login flow এর পুরো প্রক্রিয়া পরীক্ষা করা হচ্ছে, যেখানে ব্যবহারকারী লগইন পেজে গিয়ে ব্যবহারকারী নাম এবং পাসওয়ার্ড ইনপুট করে সাইন ইন করার চেষ্টা করছে।

End-to-End Testing এর সুবিধা:

  • ব্যবহারকারীর অভিজ্ঞতার পূর্ণ পরীক্ষা করা হয়।
  • অ্যাপ্লিকেশনটি পুরোপুরি একত্রে সঠিকভাবে কাজ করছে কিনা তা যাচাই করা যায়।
  • সিস্টেমের সমন্বয় এবং সংহতি নিশ্চিত করা যায়।

Testing এর মধ্যে পার্থক্য:

Type of TestingScopePurposeTools
Unit Testingএকক ইউনিট/ফাংশনএকটি নির্দিষ্ট ফাংশন বা মেথডের কার্যকারিতা পরীক্ষা করাJasmine, Mocha, Jest
Integration Testingএকাধিক ইউনিট/কম্পোনেন্টবিভিন্ন ইউনিট বা মডিউলের একসাথে কাজ নিশ্চিত করাSupertest, Postman
End-to-End Testingপূর্ণ অ্যাপ্লিকেশন বা সিস্টেমসিস্টেমের সমগ্র কার্যকারিতা পরীক্ষা করাCypress, Selenium, Protractor

সারাংশ

  • Unit Testing ছোট ছোট ফাংশন বা মেথডের কার্যকারিতা পরীক্ষা করে।
  • Integration Testing বিভিন্ন ইউনিট বা মডিউলের ইন্টিগ্রেশন এবং যোগাযোগ পরীক্ষা করে।
  • End-to-End Testing (E2E) পুরো অ্যাপ্লিকেশনটি বাস্তব ব্যবহারকারীর মতো পরীক্ষা করে।

প্রতিটি ধরনের টেস্টিং অ্যাপ্লিকেশনের বিভিন্ন স্তরে কার্যকারিতা নিশ্চিত করে এবং সফটওয়্যারের নিরাপত্তা এবং মান নিশ্চিত করার জন্য গুরুত্বপূর্ণ ভূমিকা পালন করে।

Content added By

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

311

Ionic অ্যাপ্লিকেশনে টেস্টিং একটি গুরুত্বপূর্ণ অংশ, কারণ এটি আপনাকে অ্যাপ্লিকেশনের স্থিতিশীলতা এবং কার্যকারিতা নিশ্চিত করতে সাহায্য করে। টেস্টিংয়ের মাধ্যমে আপনি নিশ্চিত করতে পারেন যে অ্যাপের বিভিন্ন অংশ সঠিকভাবে কাজ করছে।

Ionic অ্যাপে টেস্টিং সাধারণত Unit Testing এবং End-to-End (E2E) Testing এর মাধ্যমে করা হয়।

এখানে Ionic অ্যাপে Test Cases তৈরি এবং চালানোর পদ্ধতি ব্যাখ্যা করা হলো।


১. Unit Testing (উইন্ডো স্তরের টেস্টিং)

Unit Testing হল একটি প্রক্রিয়া যেখানে আপনার কোডের একটি নির্দিষ্ট অংশ (যেমন ফাংশন বা মেথড) পরীক্ষিত হয়। Ionic অ্যাপে Unit Testing সাধারণত Jasmine এবং Karma ব্যবহার করে করা হয়।

১.১ Karma এবং Jasmine সেটআপ

Ionic প্রকল্পে Karma এবং Jasmine এর মাধ্যমে টেস্টিং করার জন্য প্রথমে কিছু প্রয়োজনীয় প্যাকেজ ইনস্টল করতে হবে।

npm install --save-dev karma karma-chrome-launcher karma-jasmine karma-jasmine-html-reporter @angular-devkit/build-angular

১.২ Test Case তৈরি করা

Ionic অ্যাপে Test Case তৈরি করতে হলে, আপনাকে .spec.ts ফাইল ব্যবহার করতে হবে। এটি ঐ কম্পোনেন্ট বা সার্ভিসের সাথে সম্পর্কিত টেস্ট ফাইল হবে।

উদাহরণ হিসেবে, HomePage কম্পোনেন্টের জন্য একটি unit test ফাইল তৈরি করা হলো।

  1. প্রথমে home.page.ts ফাইলটিতে একটি সিম্পল ফাংশন তৈরি করুন:
import { Component } from '@angular/core';

@Component({
  selector: 'app-home',
  templateUrl: './home.page.html',
  styleUrls: ['./home.page.scss'],
})
export class HomePage {
  constructor() {}

  // একটি সিম্পল ফাংশন
  addNumbers(a: number, b: number): number {
    return a + b;
  }
}
  1. তারপর home.page.spec.ts ফাইলে unit test কোড লিখুন:
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { HomePage } from './home.page';

describe('HomePage', () => {
  let component: HomePage;
  let fixture: ComponentFixture<HomePage>;

  beforeEach(async () => {
    await TestBed.configureTestingModule({
      declarations: [ HomePage ],
    })
    .compileComponents();

    fixture = TestBed.createComponent(HomePage);
    component = fixture.componentInstance;
    fixture.detectChanges();
  });

  it('should create', () => {
    expect(component).toBeTruthy();
  });

  it('should add two numbers correctly', () => {
    const result = component.addNumbers(2, 3);
    expect(result).toBe(5);
  });
});

এখানে:

  • beforeEach: প্রতিটি টেস্ট কেস চলানোর আগে প্রস্তুতি নেয়।
  • it(): প্রতিটি টেস্ট কেসের জন্য একটি শর্ত নির্ধারণ করা হয়।
  • expect(): এখানে অ্যাসারশন করা হয়েছে যে, addNumbers() ফাংশনটি সঠিকভাবে কাজ করবে।

১.৩ Unit Test চালানো

Unit Test চালানোর জন্য কমান্ড:

ng test

এটি Karma ব্যবহার করে আপনার টেস্ট চালাবে এবং টেস্ট রেজাল্ট ব্রাউজারে দেখাবে।


২. End-to-End (E2E) Testing

End-to-End Testing (E2E) হল অ্যাপ্লিকেশনের পুরো ফ্লো টেস্ট করা। এখানে পুরো অ্যাপ্লিকেশন চালানোর সময় বিভিন্ন ইন্টারঅ্যাকশন পরীক্ষা করা হয়। Ionic অ্যাপে Protractor এবং Cypress জনপ্রিয় টুল যা E2E টেস্টিংয়ের জন্য ব্যবহৃত হয়।

২.১ Protractor Setup

Ionic প্রকল্পে E2E টেস্টিং করার জন্য Protractor ব্যবহার করতে হবে।

প্রথমে, Protractor সেটআপ করতে হবে।

npm install --save-dev protractor

২.২ E2E Test Case তৈরি করা

Ionic অ্যাপে E2E টেস্ট করার জন্য e2e/specs ফোল্ডার তৈরি হয়। এখানে home.page.e2e-spec.ts ফাইলের মাধ্যমে E2E টেস্ট করা যাবে।

import { browser, by, element } from 'protractor';

describe('HomePage', () => {
  it('should display a title', () => {
    browser.get('/');
    let title = element(by.css('ion-title')).getText();
    expect(title).toEqual('Home');
  });

  it('should add two numbers correctly', () => {
    browser.get('/');
    let input1 = element(by.id('input1'));
    let input2 = element(by.id('input2'));
    let result = element(by.id('result'));

    input1.sendKeys('2');
    input2.sendKeys('3');

    let button = element(by.id('addButton'));
    button.click();

    expect(result.getText()).toBe('5');
  });
});

এখানে:

  • browser.get('/'): অ্যাপ্লিকেশনকে হোম পেজে নিয়ে যাবে।
  • element(by.css()): DOM থেকে উপাদান নির্বাচন করা হয়।

২.৩ E2E Test চালানো

E2E টেস্ট চালাতে:

ng e2e

এটি আপনার Ionic অ্যাপের পুরোপুরি ইন্টারঅ্যাকশনের জন্য পরীক্ষা চালাবে এবং ব্রাউজারে ফলাফল দেখাবে।


৩. CI/CD ইন্টিগ্রেশন (Continuous Integration/Continuous Deployment)

CI/CD প্রক্রিয়া ব্যবহার করে টেস্টগুলো স্বয়ংক্রিয়ভাবে চালানো যায়। GitHub Actions বা GitLab CI এর মাধ্যমে আপনি Ionic অ্যাপ এর Unit Test এবং E2E Test স্বয়ংক্রিয়ভাবে চালাতে পারবেন।

উদাহরণ: GitHub Actions CI/CD পিপলাইন

name: CI

on:
  push:
    branches:
      - main

jobs:
  test:
    runs-on: ubuntu-latest

    steps:
      - name: Checkout code
        uses: actions/checkout@v2

      - name: Set up Node.js
        uses: actions/setup-node@v2
        with:
          node-version: '14'

      - name: Install dependencies
        run: npm install

      - name: Run tests
        run: npm test

এখানে, GitHub Actions এর মাধ্যমে আপনি Unit Test চালাতে পারবেন এবং CI/CD পিপলাইন তৈরি করতে পারবেন।


সারাংশ

  • Unit Testing: Ionic অ্যাপে নির্দিষ্ট ফাংশন এবং মেথড পরীক্ষা করার জন্য Jasmine এবং Karma ব্যবহার করা হয়।
  • End-to-End Testing: অ্যাপ্লিকেশনের পুরো ফ্লো পরীক্ষা করতে Protractor বা Cypress ব্যবহার করা হয়।
  • Test Automation: GitHub Actions বা GitLab CI/CD পিপলাইন ব্যবহার করে টেস্টগুলো স্বয়ংক্রিয়ভাবে চালানো যায়।

এটি আপনার অ্যাপ্লিকেশনকে আরও স্থিতিশীল এবং কার্যকরী করার জন্য সহায়ক হবে।

Content added By

Karma এবং Jasmine ব্যবহার করে Testing

331

Karma এবং Jasmine হল Angular অ্যাপ্লিকেশন এবং Ionic অ্যাপ্লিকেশনগুলির জন্য জনপ্রিয় টেস্টিং ফ্রেমওয়ার্ক। Jasmine একটি behavior-driven development (BDD) ফ্রেমওয়ার্ক যা কোডের ইউনিট টেস্টিং করতে সাহায্য করে, এবং Karma হল একটি টেস্ট রানার যা টেস্টগুলো চালানোর জন্য ব্রাউজার বা পরিবেশ সেটআপ করে। Karma ব্যবহার করে Jasmine টেস্টগুলি ব্রাউজারে রান করা যায়, এবং এটি অ্যাপ্লিকেশন কোডের জন্য টেস্টিং প্রক্রিয়া সহজ করে তোলে।

এখানে Ionic অ্যাপে Karma এবং Jasmine ব্যবহার করে টেস্টিং করার বিস্তারিত প্রক্রিয়া তুলে ধরা হলো।


১. Karma এবং Jasmine ইনস্টলেশন এবং কনফিগারেশন

Ionic অ্যাপে Jasmine এবং Karma ইনস্টল এবং কনফিগার করা খুবই সহজ, কারণ Ionic CLI দ্বারা তৈরি প্রজেক্টগুলিতে আগেই Karma এবং Jasmine কনফিগার করা থাকে।

১.১ Ionic অ্যাপে Testing Setup

Ionic প্রজেক্টে ডিফল্টভাবে Jasmine এবং Karma কনফিগারেশনসহ আসে। নতুন Ionic প্রজেক্ট তৈরি করার সময় এই টুলগুলো সরাসরি ইনস্টল হয়। যদি আপনি নতুন Ionic প্রজেক্ট তৈরি করে থাকেন, তবে আপনাকে আলাদা করে ইনস্টল করার প্রয়োজন নেই।

ionic start myApp blank --type=angular

১.২ Karma এবং Jasmine ইনস্টল করা

যদি আপনার প্রজেক্টে Karma এবং Jasmine ইনস্টল না থাকে, তবে এটি ইনস্টল করতে হবে। নিচের কমান্ডটি চালান:

npm install karma karma-jasmine karma-chrome-launcher jasmine-core --save-dev
  • karma-jasmine: Karma এর সাথে Jasmine ব্যবহার করতে।
  • karma-chrome-launcher: Chrome ব্রাউজারে টেস্ট চালানোর জন্য।
  • jasmine-core: Jasmine এর মূল প্যাকেজ।

২. Karma কনফিগারেশন ফাইল সেটআপ

Karma কনফিগারেশন ফাইলটি karma.conf.js নামে থাকবে যা টেস্ট রান করার জন্য বিভিন্ন সেটিংস ও কনফিগারেশন নির্ধারণ করে।

২.১ karma.conf.js কনফিগারেশন

Ionic CLI দ্বারা তৈরি প্রকল্পে এই কনফিগারেশনটি আগেই তৈরি থাকে। আপনি যদি এই ফাইলটি কাস্টমাইজ করতে চান, তাহলে সেটি karma.conf.js ফাইলে করতে পারেন।

module.exports = function(config) {
  config.set({
    basePath: '',
    frameworks: ['jasmine'],
    files: [
      'src/**/*.spec.ts'  // টেস্ট ফাইল
    ],
    exclude: [],
    preprocessors: {
      'src/**/*.ts': ['karma-typescript']  // TypeScript টেস্টিং
    },
    reporters: ['progress'],
    port: 9876,
    colors: true,
    logLevel: config.LOG_INFO,
    autoWatch: true,
    browsers: ['Chrome'],  // টেস্ট চালানোর জন্য ব্রাউজার
    singleRun: false,
    concurrency: Infinity
  })
}

এখানে:

  • frameworks: আমরা jasmine ফ্রেমওয়ার্ক ব্যবহার করছি।
  • files: এখানে আপনার টেস্ট ফাইলগুলো থাকবে (বিশেষ করে .spec.ts ফাইলগুলো)।
  • browsers: Chrome ব্রাউজারে টেস্ট রান করার জন্য সেট করা হয়েছে।

৩. Test File Structure

কোনো টেস্ট ফাইল .spec.ts এক্সটেনশনে তৈরি করা হয়। এই ফাইলের মধ্যে আপনি আপনার কোডের ইউনিট টেস্টিং কোড লিখবেন। সাধারণভাবে, .spec.ts ফাইলগুলি আপনার কম্পোনেন্ট, সার্ভিস, অথবা ডিরেকটিভের জন্য টেস্ট লেখার স্থান।

৩.১ কম্পোনেন্ট টেস্ট করা

ধরা যাক, একটি HomeComponent আছে এবং আপনি এটি টেস্ট করতে চান।

home.component.ts:

import { Component } from '@angular/core';

@Component({
  selector: 'app-home',
  templateUrl: './home.component.html',
  styleUrls: ['./home.component.css']
})
export class HomeComponent {
  message = 'Hello, world!';
}

এখন, home.component.spec.ts ফাইলে এর টেস্ট লিখবেন:

home.component.spec.ts:

import { ComponentFixture, TestBed } from '@angular/core/testing';
import { HomeComponent } from './home.component';

describe('HomeComponent', () => {
  let component: HomeComponent;
  let fixture: ComponentFixture<HomeComponent>;

  beforeEach(() => {
    TestBed.configureTestingModule({
      declarations: [HomeComponent]
    });
    fixture = TestBed.createComponent(HomeComponent);
    component = fixture.componentInstance;
    fixture.detectChanges();
  });

  it('should create', () => {
    expect(component).toBeTruthy();
  });

  it('should have the correct message', () => {
    expect(component.message).toBe('Hello, world!');
  });
});

এখানে:

  • beforeEach(): এই ফাংশনটি প্রতিটি টেস্টের আগে রান হয় এবং কম্পোনেন্ট ইনস্ট্যান্স তৈরি করে।
  • it(): টেস্ট কেস লিখতে ব্যবহৃত হয়।
  • expect() দ্বারা নির্ধারিত আউটপুটের সাথে মূল্যায়ন করা হয়।

৪. সার্ভিস টেস্ট করা

একটি সার্ভিস টেস্ট করার জন্য HttpClientTestingModule ব্যবহার করতে হবে যদি আপনি HTTP কল করতে চান। এখানে আমরা একটি সার্ভিস টেস্ট করার উদাহরণ দেখাবো।

user.service.ts:

import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Observable } from 'rxjs';

@Injectable({
  providedIn: 'root'
})
export class UserService {

  constructor(private http: HttpClient) {}

  getUserData(): Observable<any> {
    return this.http.get('https://api.example.com/user');
  }
}

এখন user.service.spec.ts ফাইলের মধ্যে এর টেস্ট লিখুন:

user.service.spec.ts:

import { TestBed } from '@angular/core/testing';
import { HttpClientTestingModule, HttpTestingController } from '@angular/common/http/testing';
import { UserService } from './user.service';

describe('UserService', () => {
  let service: UserService;
  let httpMock: HttpTestingController;

  beforeEach(() => {
    TestBed.configureTestingModule({
      imports: [HttpClientTestingModule],
      providers: [UserService]
    });
    service = TestBed.inject(UserService);
    httpMock = TestBed.inject(HttpTestingController);
  });

  it('should fetch user data', () => {
    const mockData = { name: 'John', age: 30 };

    service.getUserData().subscribe(data => {
      expect(data).toEqual(mockData);
    });

    const req = httpMock.expectOne('https://api.example.com/user');
    expect(req.request.method).toBe('GET');
    req.flush(mockData);
  });

  afterEach(() => {
    httpMock.verify();
  });
});

এখানে:

  • HttpClientTestingModule: HTTP টেস্টিংয়ের জন্য এটি ব্যবহৃত হয়।
  • httpMock: HTTP কল পরীক্ষা করার জন্য ব্যবহৃত হয়।

৫. Karma Test Run

যখন আপনি টেস্টগুলি লিখে ফেলবেন, তখন আপনার টেস্ট চালানোর জন্য কেবল নিচের কমান্ডটি চালান:

ng test

এটি Karma রানের মাধ্যমে আপনার টেস্টগুলি চালাবে এবং ব্রাউজারে ফলাফল দেখাবে।


সারাংশ

  • Karma এবং Jasmine হল দুটি শক্তিশালী টুল যা Ionic অ্যাপ্লিকেশন এবং Angular অ্যাপ্লিকেশনের জন্য টেস্টিং সমাধান প্রদান করে।
  • Jasmine ব্যবহার করে আপনি অ্যাপ্লিকেশন লজিকের জন্য ইউনিট টেস্ট লিখতে পারেন, এবং Karma ব্যবহার করে সেগুলি ব্রাউজারে চালিয়ে দেখতে পারেন।
  • Ionic অ্যাপ্লিকেশন তৈরি করার সময় আপনার কোডের কম্পোনেন্ট, সার্ভিস এবং অন্যান্য অংশের জন্য টেস্ট লিখে নিশ্চিত করতে পারেন যে সবকিছু সঠিকভাবে কাজ করছে।

এভাবে আপনি Ionic অ্যাপে কার্যকরী টেস্টিং কৌশল ব্যবহার করতে পারবেন এবং কোডের কোয়ালিটি নিশ্চিত করতে পারবেন।

Content added By

Debugging এবং Chrome DevTools ব্যবহার

361

Debugging বা বাগ অনুসন্ধান একটি অত্যন্ত গুরুত্বপূর্ণ প্রক্রিয়া যা সফটওয়্যার ডেভেলপমেন্টের প্রতিটি পর্যায়ে ব্যবহার করা হয়। Angular অ্যাপ্লিকেশনে বা যেকোনো ওয়েব অ্যাপ্লিকেশনে Chrome DevTools ব্যবহার করে আপনি কোডের সমস্যা চিহ্নিত করতে পারেন। Chrome DevTools হল একটি ব্রাউজার টুলস যা আপনার অ্যাপ্লিকেশনের পারফরম্যান্স এবং বাগগুলো ডিবাগ করতে সহায়ক।

এখানে আমরা Chrome DevTools এর কিছু গুরুত্বপূর্ণ ফিচার এবং debugging পদ্ধতি নিয়ে আলোচনা করবো।


১. Chrome DevTools কী?

Chrome DevTools হল Google Chrome ব্রাউজারে অন্তর্ভুক্ত একটি ডিবাগিং টুলস যা আপনাকে HTML, CSS, JavaScript, Network, Console ইত্যাদি পর্যবেক্ষণ এবং ডিবাগ করতে সাহায্য করে। এটি ডেভেলপারদের ওয়েব অ্যাপ্লিকেশনগুলোকে দ্রুত ডিবাগ এবং অপটিমাইজ করতে সহায়ক।


২. Chrome DevTools ব্যবহার করা

২.১ DevTools খুলা

Chrome DevTools খোলার জন্য আপনার Chrome ব্রাউজারে নিচের যেকোনো পদ্ধতি অনুসরণ করতে পারেন:

  • Right-click করুন এবং Inspect সিলেক্ট করুন।
  • কিবোর্ড থেকে F12 অথবা Ctrl + Shift + I (Windows/Linux) বা Cmd + Option + I (macOS) চাপুন।
  • আপনি যখন Angular অ্যাপ চলাচল করাচ্ছেন তখন ng serve এর মাধ্যমে অ্যাপ রান করান এবং DevTools খুলুন।

২.২ Console Tab

Console ট্যাবটি আপনার অ্যাপের log মেসেজ, ত্রুটি, বা ওয়ার্নিং দেখানোর জন্য ব্যবহৃত হয়। এটি ডেভেলপারদের জন্য অত্যন্ত সহায়ক, কারণ আপনি এখানে console.log(), console.error() ইত্যাদি দিয়ে ডিবাগ মেসেজ দেখতে পারবেন।

console.log('This is a debug message');
console.error('This is an error message');

এছাড়া আপনি সরাসরি JavaScript কোড রান করতেও পারেন। এটি কোডের ভুল চিহ্নিত করার জন্য খুবই কার্যকরী।

২.৩ Elements Tab

Elements ট্যাবে আপনি অ্যাপের DOM (Document Object Model) দেখতে এবং সম্পাদনা করতে পারেন। এটি আপনাকে HTML এবং CSS স্টাইল ম্যানিপুলেট করতে সহায়ক।

  • HTML ট্যাব থেকে, আপনি DOM-এ কোন পরিবর্তন ঘটিয়েছেন তা সনাক্ত করতে পারেন।
  • আপনি CSS স্টাইল পরিবর্তন করতে এবং রিয়েল-টাইমে পছন্দের ডিজাইন দেখতে পারেন।

২.৪ Sources Tab

Sources ট্যাবে আপনি অ্যাপের কোড ডিবাগ করতে পারেন। এটি JavaScript কোডের মধ্যে ব্রেকপয়েন্ট সেট করতে এবং ডিবাগ করতে ব্যবহৃত হয়।

২.৪.১ Breakpoints ব্যবহার করা
  1. Breakpoints হল এমন পয়েন্ট যেখানে কোড রান হওয়ার সময় থামবে। এটি ব্যবহার করে আপনি কোড এক্সিকিউশন এবং ভেরিয়েবলের মান পর্যবেক্ষণ করতে পারেন।
  2. Breakpoint সেট করা:
    • Sources ট্যাবে যান এবং আপনার স্ক্রিপ্ট ফাইল খুঁজে বের করুন।
    • যেই লাইনে ব্রেকপয়েন্ট সেট করতে চান, সেখানকার লাইনের পাশে ক্লিক করুন। ব্রেকপয়েন্ট হালকা নীল রঙে চিহ্নিত হবে।
    • ব্রেকপয়েন্টে কোড থামানো হলে, আপনি Step Over, Step Into, Step Out বাটন ব্যবহার করে কোডের এক্সিকিউশন স্টেপ বাই স্টেপ করতে পারবেন।

২.৫ Network Tab

Network ট্যাবটি API কল, রিসোর্স লোড, এবং অন্যান্য নেটওয়ার্ক রিকোয়েস্ট ট্র্যাক করতে ব্যবহৃত হয়। এটি বিশেষভাবে অ্যাপ্লিকেশনের সার্ভার থেকে ডেটা ফেচ করার সময় সহায়ক।

২.৫.১ Network Request ট্র্যাকিং
  • এখানে আপনি সমস্ত HTTP রিকোয়েস্ট যেমন GET, POST, PUT, DELETE দেখতে পাবেন।
  • আপনি রিকোয়েস্টের স্ট্যাটাস কোড, হেডার, রেসপন্স টাইম, এবং রেসপন্স বডি দেখেতে পারেন।
  • XHR (XMLHttpRequest) বা Fetch রিকোয়েস্টের মাধ্যমে API কলের ডিবাগ করতে পারবেন।

২.৬ Performance Tab

Performance ট্যাবটি আপনার অ্যাপ্লিকেশনের পারফরম্যান্স এবং কোড এক্সিকিউশন বিশ্লেষণ করতে ব্যবহৃত হয়।

  • আপনি অ্যাপের লোডিং টাইম, স্ক্রিপ্ট এক্সিকিউশন সময়, এবং DOM রেন্ডারিং এর সমস্ত ডিটেইল দেখতে পারেন।
  • এটি বিশেষভাবে প্রফাইলিং এবং পারফরম্যান্স অপটিমাইজেশনের জন্য খুবই গুরুত্বপূর্ণ।

২.৭ Application Tab

Application ট্যাবে আপনি অ্যাপ্লিকেশনের সব স্টোরেজ ম্যানেজমেন্ট দেখতে পারেন, যেমন LocalStorage, SessionStorage, IndexedDB, এবং Cookies

  • এখানে আপনি localStorage বা sessionStorage এ ডেটা সংরক্ষণ করা আছে কিনা দেখতে পারবেন এবং সেই ডেটা সরাসরি ম্যানিপুলেট করতে পারবেন।

৩. Angular Debugging with Chrome DevTools

Angular অ্যাপ্লিকেশনের জন্য কিছু অতিরিক্ত ডিবাগিং টিপস:

৩.১ Angular Augury Extension

Augury হল একটি Chrome Extension যা Angular অ্যাপ্লিকেশনের state এবং structure দেখাতে ব্যবহৃত হয়। এটি আপনাকে Angular এর কম্পোনেন্ট, রাউটিং, এবং স্টোর বুঝতে সহায়তা করে।

  1. Chrome Web Store থেকে Augury ডাউনলোড করুন।
  2. Extension ইনস্টল করার পর, Chrome DevTools এ Augury ট্যাবটি দেখুন।
  3. Angular অ্যাপ্লিকেশনের component tree এবং services এর তথ্য দেখতে পারবেন।

৩.২ Enable Angular Debugging in Code

Angular অ্যাপের মধ্যে ডিবাগিং চালু করার জন্য Angular DevTools ব্যবহার করতে পারেন, যা ng-devtools নামে একটি নতুন টুল। এটি অ্যাপের স্টেট এবং কম্পোনেন্ট লাইফসাইকেল ট্র্যাক করার জন্য ব্যবহৃত হয়।

npm install --save-dev @angular-devtools/core

এটি Angular অ্যাপের ডিবাগিং সহজ করে এবং Angular কম্পোনেন্টের ইন্টারঅ্যাকশন সহজেই বুঝতে সহায়তা করে।


Chrome DevTools একটি অত্যন্ত শক্তিশালী টুল যা ওয়েব অ্যাপ্লিকেশন ডেভেলপমেন্টের প্রতিটি পর্যায়ে কার্যকর। আপনি এই টুল ব্যবহার করে কোড ডিবাগ, পারফরম্যান্স অপটিমাইজেশন, এবং API রিকোয়েস্ট ট্র্যাক করতে পারবেন। Angular অ্যাপ্লিকেশনের জন্য DevTools আরও শক্তিশালী এবং আপনাকে বিভিন্ন ডিবাগিং টিপস এবং টুলস, যেমন Angular Augury এবং Angular DevTools, প্রদান করে।

Content added By
Promotion

Are you sure to start over?

Loading...