Firebase Local Emulator Suite ব্যবহার শুরু করার আগে, নিশ্চিত করুন যে আপনি একটি Firebase প্রজেক্ট তৈরি করেছেন, আপনার ডেভেলপমেন্ট এনভায়রনমেন্ট সেট আপ করেছেন এবং আপনার প্ল্যাটফর্মের ( Apple , Android বা Web) জন্য 'Get started with Firebase' টপিক অনুযায়ী Firebase SDK নির্বাচন ও ইনস্টল করেছেন।
প্রোটোটাইপ এবং পরীক্ষা
Local Emulator Suite বেশ কয়েকটি প্রোডাক্ট এমুলেটর রয়েছে, যেমনটি “Introduction to Firebase Local Emulator Suite এ বর্ণনা করা হয়েছে। আপনি প্রোডাকশনে কোন Firebase প্রোডাক্টগুলো ব্যবহার করছেন তার উপর ভিত্তি করে, আপনার সুবিধামতো স্বতন্ত্র এমুলেটর বা এমুলেটরের সংমিশ্রণ ব্যবহার করে প্রোটোটাইপ তৈরি ও পরীক্ষা করতে পারেন।

এই আলোচনায় Local Emulator Suite ওয়ার্কফ্লোর সাথে পরিচয় করিয়ে দেওয়ার জন্য, ধরা যাক আপনি এমন একটি অ্যাপ নিয়ে কাজ করছেন যা কয়েকটি সাধারণ প্রোডাক্টের সমন্বয়ে গঠিত: একটি ফায়ারবেস ডাটাবেস এবং সেই ডাটাবেসের অপারেশনের মাধ্যমে ট্রিগার হওয়া ক্লাউড ফাংশন।
আপনার ফায়ারবেস প্রজেক্টটি স্থানীয়ভাবে ইনিশিয়ালাইজ করার পর, Local Emulator Suite ব্যবহার করে ডেভেলপমেন্ট চক্রে সাধারণত তিনটি ধাপ থাকবে:
এমুলেটর এবং Emulator Suite UI ব্যবহার করে ইন্টারেক্টিভভাবে প্রোটোটাইপ ফিচার তৈরি করুন।
আপনি যদি ডাটাবেস এমুলেটর বা Cloud Functions এমুলেটর ব্যবহার করেন, তাহলে আপনার অ্যাপটিকে এমুলেটরগুলোর সাথে সংযুক্ত করতে একবারের জন্য এই পদক্ষেপটি গ্রহণ করুন।
এমুলেটর এবং কাস্টম স্ক্রিপ্ট ব্যবহার করে আপনার টেস্টগুলো স্বয়ংক্রিয় করুন।
স্থানীয়ভাবে একটি ফায়ারবেস প্রজেক্ট শুরু করুন
নিশ্চিত করুন যে আপনি CLI ইনস্টল করেছেন অথবা এর সর্বশেষ সংস্করণে আপডেট করেছেন ।
curl -sL firebase.tools | bashযদি আপনি ইতিমধ্যে তা না করে থাকেন, তাহলে বর্তমান ওয়ার্কিং ডিরেক্টরিটিকে একটি Firebase প্রজেক্ট হিসাবে ইনিশিয়ালাইজ করুন এবং আপনি যে Cloud Functions ও Cloud Firestore অথবা Realtime Database ব্যবহার করছেন তা নির্দিষ্ট করতে স্ক্রিনে দেওয়া নির্দেশাবলী অনুসরণ করুন।
firebase init আপনার প্রজেক্ট ডিরেক্টরিতে এখন ফায়ারবেস কনফিগারেশন ফাইল, ডাটাবেসের জন্য একটি Firebase Security Rules ডেফিনিশন ফাইল, ক্লাউড ফাংশন কোড সম্বলিত একটি functions ডিরেক্টরি এবং অন্যান্য সহায়ক ফাইল থাকবে।
ইন্টারেক্টিভভাবে প্রোটোটাইপ করুন
Local Emulator Suite আপনাকে দ্রুত নতুন ফিচারের প্রোটোটাইপ তৈরি করতে সাহায্য করার জন্য ডিজাইন করা হয়েছে, এবং এই স্যুটের বিল্ট-ইন ইউজার ইন্টারফেসটি এর সবচেয়ে দরকারি প্রোটোটাইপিং টুলগুলোর মধ্যে অন্যতম। এটি অনেকটা স্থানীয়ভাবে Firebase কনসোল চালানোর মতো।
Emulator Suite UI ব্যবহার করে, আপনি একটি ডেটাবেসের ডিজাইন পরিমার্জন করতে পারেন, ক্লাউড ফাংশন-সম্পর্কিত বিভিন্ন ডেটাফ্লো পরীক্ষা করতে পারেন, সিকিউরিটি রুলস-এর পরিবর্তনগুলো মূল্যায়ন করতে পারেন, আপনার ব্যাক-এন্ড সার্ভিসগুলো কেমন পারফর্ম করছে তা নিশ্চিত করতে লগ চেক করতে পারেন এবং আরও অনেক কিছু করতে পারেন। এরপর, যদি আপনি নতুন করে শুরু করতে চান, তবে শুধু আপনার ডেটাবেসটি খালি করে একটি নতুন ডিজাইন আইডিয়া নিয়ে আবার শুরু করুন।
আপনি যখন Local Emulator Suite চালু করবেন, তখন এই সবকিছুই পাওয়া যাবে:
firebase emulators:startআমাদের কাল্পনিক অ্যাপটির প্রোটোটাইপ তৈরি করার জন্য, চলুন একটি ডাটাবেসের টেক্সট এন্ট্রি পরিবর্তন করার জন্য একটি সাধারণ ক্লাউড ফাংশন সেট আপ ও পরীক্ষা করি এবং এটিকে চালু করার জন্য Emulator Suite UI তে সেই ডাটাবেসটি তৈরি ও ডেটা দিয়ে পূর্ণ করি।
- আপনার প্রজেক্ট ডিরেক্টরিতে থাকা
functions/index.jsফাইলটি এডিট করে ডাটাবেস রাইট দ্বারা ট্রিগার হওয়া একটি ক্লাউড ফাংশন তৈরি করুন। বিদ্যমান ফাইলটির বিষয়বস্তু নিচের কোড স্নিপেটটি দিয়ে প্রতিস্থাপন করুন। এই ফাংশনটিmessagesকালেকশনের ডকুমেন্টগুলোর পরিবর্তন পর্যবেক্ষণ করে, ডকুমেন্টটিরoriginalফিল্ডের বিষয়বস্তুকে আপারকেসে রূপান্তর করে এবং ফলাফলটি সেই ডকুমেন্টেরuppercaseফিল্ডে সংরক্ষণ করে। firebase emulators:startদিয়ে Local Emulator Suite চালু করুন। Cloud Functions এবং ডাটাবেস এমুলেটরগুলো চালু হয়ে যাবে এবং একে অপরের সাথে কাজ করার জন্য স্বয়ংক্রিয়ভাবে কনফিগার হয়ে যাবে।- আপনার ব্রাউজারে
http://localhost:4000ঠিকানায় UI দেখুন। UI-এর জন্য ডিফল্ট পোর্ট হলো 4000, কিন্তু Firebase CLI দ্বারা আউটপুট হওয়া টার্মিনাল মেসেজগুলো পরীক্ষা করুন। উপলব্ধ এমুলেটরগুলোর অবস্থা লক্ষ্য করুন। আমাদের ক্ষেত্রে, Cloud Functions এবং Cloud Firestore এমুলেটরগুলো চালু থাকবে।

- UI-তে, Firestore > Data ট্যাবে, Start collection-এ ক্লিক করুন এবং
messagesকালেকশনেoriginalফিল্ডনেম ও `testভ্যালু দিয়ে একটি নতুন ডকুমেন্ট তৈরি করতে নির্দেশাবলী অনুসরণ করুন। এটি আমাদের ক্লাউড ফাংশনটি ট্রিগার করবে। লক্ষ্য করুন যে, কিছুক্ষণের মধ্যেই একটি নতুনuppercaseফিল্ড প্রদর্শিত হবে, যেখানে "TEST" স্ট্রিংটি লেখা থাকবে।


- Firestore > Requests ট্যাবে, আপনার অনুকৃত ডেটাবেসে করা অনুরোধগুলি পরীক্ষা করুন, যার মধ্যে সেই অনুরোধগুলি পূরণ করার অংশ হিসাবে সম্পাদিত সমস্ত Firebase Security Rules মূল্যায়নও অন্তর্ভুক্ত রয়েছে।
- আপনার ফাংশনটি ডাটাবেস আপডেট করার সময় কোনো ত্রুটির সম্মুখীন হয়নি তা নিশ্চিত করতে লগস ট্যাবটি দেখুন।
const functions = require('firebase-functions/v1'); exports.makeUppercase = functions.firestore.document('/messages/{documentId}') .onCreate((snap, context) => { const original = snap.data().original; console.log('Uppercasing', context.params.documentId, original); const uppercase = original.toUpperCase(); return snap.ref.set({uppercase}, {merge: true}); });
ইন-অ্যাপ ডাটাবেস অ্যাক্সেস কোডে হাত না দিয়ে, বা টেস্ট স্যুট রি-কম্পাইল ও রি-রান না করেই, আপনি আপনার ক্লাউড ফাংশন কোড এবং ইন্টারেক্টিভ ডাটাবেস এডিটের মধ্যে সহজেই পুনরাবৃত্তি করতে পারবেন, যতক্ষণ না আপনি আপনার কাঙ্ক্ষিত ডেটা ফ্লোটি পাচ্ছেন।
আপনার অ্যাপটিকে এমুলেটরগুলির সাথে সংযুক্ত করুন
যখন আপনি ইন্টারেক্টিভ প্রোটোটাইপিংয়ে যথেষ্ট অগ্রগতি করবেন এবং একটি ডিজাইন চূড়ান্ত করবেন, তখন আপনি উপযুক্ত SDK ব্যবহার করে আপনার অ্যাপে ডাটাবেস অ্যাক্সেস কোড যোগ করার জন্য প্রস্তুত হবেন। আপনার অ্যাপের আচরণ সঠিক আছে কিনা তা নিশ্চিত করতে আপনি Emulator Suite UI এর ডাটাবেস ট্যাব এবং ফাংশনগুলোর জন্য লগস ট্যাব ব্যবহার করতে থাকবেন।
মনে রাখবেন যে Local Emulator Suite একটি স্থানীয় ডেভেলপমেন্ট টুল। আপনার প্রোডাকশন ডেটাবেসে রাইট করলে, আপনি স্থানীয়ভাবে যে ফাংশনগুলোর প্রোটোটাইপিং করছেন, সেগুলো চালু হবে না।
আপনার অ্যাপকে ডেটাবেসে লেখার ক্ষমতা দিতে হলে, আপনাকে আপনার টেস্ট ক্লাস বা ইন-অ্যাপ কনফিগারেশনকে Cloud Firestore এমুলেটরের দিকে নির্দেশ করতে হবে।
Kotlin
// 10.0.2.2 is the special IP address to connect to the 'localhost' of // the host computer from an Android emulator. val firestore = Firebase.firestore firestore.useEmulator("10.0.2.2", 8080) firestore.firestoreSettings = firestoreSettings { isPersistenceEnabled = false }
Java
// 10.0.2.2 is the special IP address to connect to the 'localhost' of // the host computer from an Android emulator. FirebaseFirestore firestore = FirebaseFirestore.getInstance(); firestore.useEmulator("10.0.2.2", 8080); FirebaseFirestoreSettings settings = new FirebaseFirestoreSettings.Builder() .setPersistenceEnabled(false) .build(); firestore.setFirestoreSettings(settings);
সুইফট
let settings = Firestore.firestore().settings settings.host = "127.0.0.1:8080" settings.cacheSettings = MemoryCacheSettings() settings.isSSLEnabled = false Firestore.firestore().settings = settings
Web
import { getFirestore, connectFirestoreEmulator } from "firebase/firestore"; // firebaseApps previously initialized using initializeApp() const db = getFirestore(); connectFirestoreEmulator(db, '127.0.0.1', 8080);
Web
// Firebase previously initialized using firebase.initializeApp(). var db = firebase.firestore(); if (location.hostname === "localhost") { db.useEmulator("127.0.0.1", 8080); }
কাস্টম স্ক্রিপ্ট দিয়ে আপনার টেস্টগুলো স্বয়ংক্রিয় করুন
এবার সামগ্রিক ওয়ার্কফ্লোর শেষ ধাপ। একবার আপনি অ্যাপের মধ্যে আপনার ফিচারের প্রোটোটাইপ তৈরি করে ফেললে এবং সেটি আপনার সব প্ল্যাটফর্মে আশাব্যঞ্জক মনে হলে, আপনি চূড়ান্ত বাস্তবায়ন এবং পরীক্ষার দিকে এগোতে পারেন। ইউনিট টেস্টিং এবং CI ওয়ার্কফ্লোর জন্য, আপনি exec কমান্ডের মাধ্যমে একটিমাত্র কলে এমুলেটর চালু করতে, স্ক্রিপ্টেড টেস্ট চালাতে এবং এমুলেটর বন্ধ করতে পারেন:
firebase emulators:exec "./testdir/test.sh"স্বতন্ত্র এমুলেটরগুলো আরও গভীরভাবে অন্বেষণ করুন।
এখন যেহেতু আপনি দেখেছেন যে মৌলিক ক্লায়েন্ট-সাইড ওয়ার্কফ্লো দেখতে কেমন, আপনি স্যুটের অন্তর্ভুক্ত স্বতন্ত্র এমুলেটরগুলো সম্পর্কে বিস্তারিত জানতে পারেন, যার মধ্যে সার্ভার-সাইড অ্যাপ ডেভেলপমেন্টের জন্য সেগুলো কীভাবে ব্যবহার করতে হয় তাও রয়েছে:
- আপনার প্রোটোটাইপিং ওয়ার্কফ্লোতে Authentication এমুলেটরটি যোগ করুন।
- Realtime Database এমুলেটরের বৈশিষ্ট্যগুলো সম্পর্কে বিস্তারিত জানুন
- Cloud Storage for Firebase বৈশিষ্ট্যগুলো সম্পর্কে বিস্তারিত জানুন।
- Cloud Firestore এমুলেটরের বৈশিষ্ট্যগুলো সম্পর্কে বিস্তারিত জানুন।
- আপনার অ্যাপটিকে ক্লাউড ফাংশনস এমুলেটরের সাথে সংযুক্ত করুন।
- Extensions এমুলেটরের সাহায্যে বিলিং খরচ কমিয়ে Firebase Extensions মূল্যায়ন করুন।
এরপর কী?
উপরে লিঙ্ক করা নির্দিষ্ট এমুলেটর-সম্পর্কিত বিষয়গুলো অবশ্যই পড়ুন। তারপর:
- নির্বাচিত ভিডিও এবং বিস্তারিত নির্দেশনামূলক উদাহরণের জন্য, ফায়ারবেস এমুলেটর প্রশিক্ষণ প্লেলিস্টটি অনুসরণ করুন।
- সিকিউরিটি রুলস টেস্টিং এবং ফায়ারবেস টেস্ট এসডিকে-এর সাথে জড়িত উন্নত ব্যবহারের ক্ষেত্রগুলো অনুসন্ধান করুন: সিকিউরিটি রুলস পরীক্ষা করুন ( Cloud Firestore ) , সিকিউরিটি রুলস পরীক্ষা করুন ( Realtime Database ) , এবং সিকিউরিটি রুলস পরীক্ষা করুন ( Cloud Storage for Firebase ) ।