Debugging Techniques এবং Tools

Web Development - এক্সটিজেএস (ExtJS) - ExtJS Unit Testing এবং Debugging |
2

Debugging বা ত্রুটি শনাক্তকরণ এবং সমাধান করা প্রতিটি ডেভেলপার ও টেস্টারের জন্য একটি গুরুত্বপূর্ণ কাজ। যখন আপনি ExtJS অ্যাপ্লিকেশন তৈরি করেন, তখন বিভিন্ন ধরণের ত্রুটি (যেমন কোডিং ত্রুটি, UI ত্রুটি, পারফরম্যান্স ত্রুটি) হতে পারে, এবং এগুলির জন্য সঠিক ডিবাগিং টেকনিক এবং টুলস ব্যবহার করা প্রয়োজন।

এখানে ExtJS Debugging Techniques এবং Tools নিয়ে আলোচনা করা হবে, যা আপনাকে কোডের ত্রুটি সনাক্ত করতে এবং সমাধান করতে সাহায্য করবে।


১. Console Logging

Console logging হল সবচেয়ে সাধারণ এবং শক্তিশালী debugging টেকনিক, যা কোডের মধ্যে কোথাও ত্রুটি ঘটছে কি না, তা দেখতে সাহায্য করে। ExtJS তে, আপনি console.log(), console.error(), console.warn() ইত্যাদি ব্যবহার করতে পারেন।

Console Logging উদাহরণ:

Ext.application({
    name: 'MyApp',
    launch: function() {
        // Example of console log
        console.log('App has been launched');
        
        try {
            // Some code that might throw an error
            var sum = 10 / 0;
            console.log('Sum: ' + sum); // This will log Infinity
        } catch (error) {
            console.error('Error occurred: ', error);
        }
    }
});

ব্যাখ্যা:

  • console.log(): সাধারণ ইনফরমেশন প্রদর্শন করতে ব্যবহৃত হয়।
  • console.error(): ত্রুটি সম্পর্কে তথ্য প্রদর্শন করতে ব্যবহৃত হয়।
  • console.warn(): সতর্কতা সম্পর্কিত তথ্য দেখানোর জন্য ব্যবহার করা হয়।

এটি ইউজার ইন্টারফেসের মধ্যে একটি নির্দিষ্ট সমস্যা বা কোডের মধ্যে কোথাও কী ঘটছে তা সহজে ট্র্যাক করতে সাহায্য করে।


২. ExtJS Inspector

ExtJS Inspector একটি পিপলিন-ভিত্তিক ডিবাগিং টুল যা ExtJS অ্যাপ্লিকেশনের DOM কাঠামো এবং কম্পোনেন্ট হায়ারার্কি পরীক্ষা করতে ব্যবহৃত হয়। এটি আপনাকে ExtJS কম্পোনেন্টের অন্তর্নিহিত স্টেট, প্রপার্টি, এবং ইভেন্টগুলি দেখতে দেয়।

ExtJS Inspector এর ব্যবহার:

  1. ExtJS Inspector ইনস্টল এবং চালানো খুবই সহজ:
    • Google Chrome বা Firefox ব্রাউজারে ডেভেলপার টুলস থেকে ExtJS Inspector এক্সটেনশন ইনস্টল করুন।
    • তারপর আপনি যে অ্যাপ্লিকেশনটি ডিবাগ করতে চান, সেখানে ExtJS Inspector ট্যাব দেখতে পাবেন।
  2. Inspector ব্যবহার:
    • আপনার অ্যাপ্লিকেশন লোড হওয়ার পর, ExtJS Inspector ট্যাবটি খোলার মাধ্যমে আপনি অ্যাপ্লিকেশনের সমস্ত ExtJS কম্পোনেন্ট দেখতে এবং তাদের প্রপার্টি পরীক্ষা করতে পারবেন।

এটি ডায়নামিকভাবে কম্পোনেন্টের স্টেট পরীক্ষা করতে এবং UI ত্রুটি শনাক্ত করতে সহায়ক।


৩. Breakpoints এবং Debugger (Browser Developer Tools)

ডেভেলপার টুলসের মাধ্যমে breakpoints ব্যবহার করে আপনি আপনার কোডের যেকোনো লাইনে থামাতে পারেন, এবং তারপর স্টেপ বাই স্টেপ কোড এক্সিকিউশন ট্র্যাক করতে পারেন। এটি আপনাকে কোডের কার্যকারিতা বুঝতে এবং সঠিকভাবে ডিবাগ করতে সাহায্য করে।

Browser Developer Tools (Chrome DevTools) উদাহরণ:

  1. Breakpoints ব্যবহার:
    • Chrome DevTools এ গিয়ে, Sources ট্যাব নির্বাচন করুন।
    • আপনার JavaScript ফাইলটি খুঁজুন এবং যেখানে আপনি থামাতে চান সেই লাইনে ক্লিক করুন।
    • একবার ব্রেকপয়েন্ট সেট হলে, আপনি কোডে থামতে পারবেন এবং step through করে কোড এক্সিকিউশন দেখতে পারবেন।
  2. Code Stepping:
    • Step Over: একটি ফাংশনের ভিতরে না গিয়ে পরবর্তী লাইনে চলে যান।
    • Step Into: ফাংশনের ভিতরে চলে যান এবং এক্সিকিউশন ট্র্যাক করুন।
    • Step Out: বর্তমান ফাংশন থেকে বের হয়ে পরবর্তী স্টেটমেন্টে চলে যান।
  3. Console Debugging:

    • ব্রাউজার ডেভেলপার টুলসের Console ট্যাব ব্যবহার করে আপনি debugger কল করে কোডে থামাতে পারেন।
    debugger; // Add this line to set a breakpoint programmatically
    

এটি আপনাকে কোডের ভিতরের সমস্যা সনাক্ত করতে সাহায্য করবে।


৪. ExtJS Ext-Ajax Requests Debugging

AJAX রিকোয়েস্টগুলো ডিবাগ করার জন্য আপনি Ext.Ajax এর ইভেন্ট হ্যান্ডলার ব্যবহার করতে পারেন এবং রিকোয়েস্ট সাপোর্ট চেক করতে পারেন। এর মাধ্যমে, আপনি API কল এবং সার্ভার রেসপন্স চেক করতে পারবেন।

Ext.Ajax Request Debugging উদাহরণ:

Ext.Ajax.request({
    url: '/api/data',
    method: 'GET',
    success: function(response) {
        console.log('Data received: ', response.responseText);
    },
    failure: function(response) {
        console.error('Failed to load data', response.statusText);
    },
    callback: function() {
        console.log('Request completed');
    }
});

ব্যাখ্যা:

  • success: সার্ভার থেকে সফলভাবে রেসপন্স পাওয়া গেলে এটি চালিত হয়।
  • failure: সার্ভার রেসপন্সে ত্রুটি হলে এটি চালিত হয়।
  • callback: রিকোয়েস্ট শেষ হওয়ার পর এটি চালিত হয়, সফল বা ব্যর্থ যাই হোক না কেন।

এটি ডিবাগিং এর মাধ্যমে API কলের রেসপন্স মনিটর করার জন্য উপকারী।


৫. Testing Frameworks for Debugging

ডিবাগিং টেকনিকের সাথে সঙ্গতিপূর্ণভাবে, আপনি Testing Frameworks ব্যবহার করে কোডের ভিন্ন ভিন্ন অংশ পরীক্ষা করতে পারেন। ExtJS তে Jasmine, Siesta বা QUnit এর মতো টেস্টিং ফ্রেমওয়ার্ক দিয়ে আপনি ইউনিট টেস্ট, ইন্টিগ্রেশন টেস্ট, এবং ফাংশনাল টেস্ট লিখে ত্রুটির জন্য অ্যাপ্লিকেশন পরীক্ষা করতে পারেন।

Jasmine Testing Framework উদাহরণ:

describe('MyComponent Test', function() {
    it('should have a title', function() {
        var component = Ext.create('Ext.Component', {
            html: 'Hello World'
        });
        expect(component.html).toBe('Hello World');
    });
});
  • describe: টেস্টের একটি গ্রুপ তৈরি করে।
  • it: একটি একক টেস্ট কেস যা একটি একক পরীক্ষা করে।

Jasmine, Siesta বা QUnit ব্যবহার করে, আপনি আপনার ExtJS অ্যাপ্লিকেশনের প্রতিটি ইউনিটকে যাচাই করতে পারবেন এবং কোডের ত্রুটি সহজে চিহ্নিত করতে পারবেন।


সারাংশ

  • Console Logging: কোডের মধ্যে console.log() ব্যবহার করে ডিবাগিং করা, যা ত্রুটি এবং তথ্য মুদ্রণ করতে সাহায্য করে।
  • ExtJS Inspector: একটি টুল যা ExtJS কম্পোনেন্টের ইনস্পেকশন এবং তাদের প্রপার্টি দেখতে সাহায্য করে।
  • Breakpoints: ব্রাউজার ডেভেলপার টুলসের মাধ্যমে কোডে থামানো এবং স্টেপ বাই স্টেপ এক্সিকিউশন ট্র্যাক করা।
  • AJAX Request Debugging: Ext.Ajax এর মাধ্যমে সার্ভার রিকোয়েস্ট এবং রেসপন্স ডিবাগ করা।
  • Testing Frameworks: Jasmine, Siesta, বা QUnit ব্যবহার করে টেস্টিং ফ্রেমওয়ার্কে ডিবাগিং করা।

এই টুলস এবং টেকনিকগুলি আপনাকে ExtJS অ্যাপ্লিকেশন ডিবাগিংয়ে সাহায্য করবে এবং অ্যাপ্লিকেশনের ত্রুটি চিহ্নিত করা এবং সমাধান করা সহজ করে তুলবে।

Content added By
Promotion