⊗jsrxPmSDIM 37 of 57 menu

Redux-এ সার্ভার সাইডের সাথে কাজ করার জন্য MSW ইনস্টল করা

গত কয়েকটি লেসনে আমরা আমাদের অ্যাপ্লিকেশনে কিছু অতিরিক্ত পরিবর্তন করেছি। এখন আমাদের সার্ভার নিয়ে কাজ করতে হবে, যার সাথে আমাদের অ্যাপ্লিকেশন ডেটা বিনিময় করবে।

আমাদের কাছে কোনও আসল সার্ভার থাকবে না, তাই আমরা শুধু এর কাজ অনুকরণ করব, ব্যবহার করে দারুণ একটি টুল Mock Service Worker. Mock Service Worker (MSW) হলো API মকিং এর একটি টুল যা স্ট্যান্ডার্ডাইজড API Service Worker ব্যবহার করে, যা নেটওয়ার্ক লেভেলে রিকোয়েস্ট ইন্টারসেপ্ট করার জন্য ডিজাইন করা। MSW আমাদের রিকোয়েস্ট (requests) এর জন্য নকল রেসপন্স (responses) জেনারেট করবে। এবং, ডেভেলপাররা দাবি করেন যে, টুলটি এতটাই কার্যকরী এবং নমনীয় যে মকগুলোর সাথে ডিবাগ করার পর (যার জন্য অ্যাপ্লিকেশনে কোনও বিশেষ কিছু তৈরি করার প্রয়োজন নেই), অ্যাপ্লিকেশনটি ইতিমধ্যেই আসল এক্সটার্নাল সার্ভারের সাথে কাজে লাগানো যেতে পারে। এর ডকুমেন্টেশন বেশ বিস্তৃত, এবং, যদি আপনি MSW নিয়ে আগ্রহী হন, আপনি এটি পড়তে পারেন অফিসিয়াল ওয়েবসাইটে।

চলুন এখন msw ইনস্টল করতে এগিয়ে যাই। এর জন্য আমাদের প্রোডাক্ট প্রজেক্টটি খুলুন এবং টার্মিনালে নিচের কমান্ডটি লিখুন:

npm install msw --save-dev

msw কাজ করার জন্য আমাদের তৈরি করতে হবে এবং কপি করতে হবে mockServiceWorker.js ফাইলটি কোনও পাবলিক ডিরেক্টরিতে। প্রায়শই এটি public ফোল্ডার। আমাদের খালি public ফোল্ডার আছে, চলুন এটিতে ফাইলটি কপি করি। এর জন্য টার্মিনালে কমান্ড রান করুন এবং তারপর public ব্যবহার করতে সম্মত হন:

npx msw init public

এখন public ফোল্ডারে দেখুন, সেখানে জেনারেট 된 স্ক্রিপ্ট mockServiceWorker.js থাকা উচিত। এখন আমাদের প্রোডাক্ট অ্যাপ্লিকেশনটি রান করুন এবং ব্রাউজারের অ্যাড্রেস বারে লিখুন http://localhost:5173/mockServiceWorker.js (যেহেতু আমাদের অ্যাপ্লিকেশনটি 5173 পোর্টে চলে)। আপনি কি ব্রাউজার উইন্ডোতে ফাইলের কন্টেন্ট দেখতে পাচ্ছেন mockServiceWorker.js? তাহলে সব ভালো, এগিয়ে যাই।

এরপর চলুন src ফোল্ডারে একটি ফোল্ডার তৈরি করি api, এবং তার মধ্যে একটি ফাইল server.js, যেখানে আমরা সার্ভারের কোড লিখব। এখন server.js খুলুন এবং এতে ইম্পোর্ট করুন setupWorker ফাংশনটি ইনস্টল করা msw লাইব্রেরি থেকে:

import { setupWorker } from 'msw/browser'

নিচে ফাইলে একটি ভেরিয়েবল তৈরি করি worker এবং এক্সপোর্ট করি:

export const worker = setupWorker()

এবং এখন চলুন main.jsx ফাইলটি খুলুন এবং এতে আমাদের ওয়ার্কার ইম্পোর্ট করি:

import { worker } from './api/server'

এখন এটিকে আমাদের অ্যাপ্লিকেশনের সাথে সংযুক্ত করি। এর জন্য যে কোড দিয়ে আমরা React অ্যাপ্লিকেশনের রুট তৈরি করি, আমরা এটিকে একটি ফাংশনে র্যাপ করব, এর নাম দিই main এবং এর প্রথম লাইনে ওয়ার্কার চালু করার জন্য ফাংশন যোগ করি। অবশ্যই ভুলবেন না main কে কল করতে। সমস্ত ইম্পোর্ট লাইনের পরে সম্পূর্ণ কোড এখন এইরকম দেখাবে:

async function main() { await worker.start({ onUnhandledRequest: 'bypass' }) ReactDOM.createRoot(document.getElementById('root')).render( <React.StrictMode> <Provider store={store}> <App /> </Provider> </React.StrictMode> ) } main()

এখন আমরা নিশ্চিত যে আমাদের অ্যাপ্লিকেশন এর আগে কাজ শুরু করবে না (এবং রিকোয়েস্ট পাঠাবে না ;) ), যতক্ষণ না ওয়ার্কার চালু হয়।

চলুন আমাদের অ্যাপ্লিকেশনটি রান করি এবং ব্রাউজারে ডেভেলপার কনসোল খুলি। যদি আপনি এতে টেক্সট দেখতে পান '[MSW] Mocking enabled.', তাহলে আপনি খুব ভালো এবং সবকিছু সঠিকভাবে ইনস্টল করেছেন!!!

আপনার স্টুডেন্ট অ্যাপ্লিকেশনটি খুলুন। এই পাঠের উপাদানটি দেখে নেওয়ার পরে, আপনার অ্যাপ্লিকেশনের জন্য Mock Service Worker ইনস্টল করুন।

server.js ফাইল তৈরি করুন, এবং এতে একটি ওয়ার্কার তৈরি করুন। worker টিকে অ্যাপ্লিকেশনের সাথে সংযুক্ত করুন main.js তে, যেমন পাঠে দেখানো হয়েছে। নিশ্চিত হন, যে সবকিছু কাজ করছে।

বাংলা
AfrikaansAzərbaycanБългарскиБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
আমরা সাইট পরিচালনা, বিশ্লেষণ এবং ব্যক্তিগতকরণের জন্য কুকি ব্যবহার করি। ডেটা প্রক্রিয়াকরণ গোপনীয়তা নীতি অনুযায়ী করা হয়।
সব গ্রহণ করুন কনফিগার করুন প্রত্যাখ্যান করুন