Firebase স্থানীয় এমুলেটর স্যুট আপনার অ্যাপের বৈশিষ্ট্য এবং আচরণ সম্পূর্ণরূপে যাচাই করা সহজ করে তোলে। এটি আপনার ফায়ারবেস নিরাপত্তা নিয়ম কনফিগারেশন যাচাই করার জন্য একটি দুর্দান্ত টুল। স্থানীয় পরিবেশে ইউনিট পরীক্ষা চালানো এবং স্বয়ংক্রিয় করতে Firebase এমুলেটর ব্যবহার করুন। এই নথিতে বর্ণিত পদ্ধতিগুলি আপনাকে সাহায্য করবে যখন আপনি আপনার অ্যাপের জন্য ইউনিট পরীক্ষাগুলি তৈরি এবং স্বয়ংক্রিয়ভাবে তৈরি করবেন যা আপনার নিয়মগুলিকে যাচাই করে৷
আপনি যদি ইতিমধ্যেই না করে থাকেন তাহলে Firebase এমুলেটর সেট আপ করুন ।
আপনি এমুলেটর চালানোর আগে
আপনি এমুলেটর ব্যবহার শুরু করার আগে, নিম্নলিখিত মনে রাখবেন:
- এমুলেটর প্রাথমিকভাবে আপনার
firebase.json
ফাইলেরfirestore.rules
বা 'storage.rules' ক্ষেত্রে নির্দিষ্ট নিয়ম লোড করবে। যদি ফাইলটি বিদ্যমান না থাকে এবং আপনি নীচে বর্ণিতloadFirestoreRules
বা 'লোডস্টোরেজ রুলস' পদ্ধতি ব্যবহার না করেন, তাহলে এমুলেটর সমস্ত প্রকল্পকে উন্মুক্ত নিয়ম হিসাবে বিবেচনা করে। - যদিও বেশিরভাগ ফায়ারবেস SDK সরাসরি এমুলেটরগুলির সাথে কাজ করে, শুধুমাত্র
@firebase/rules-unit-testing
লাইব্রেরি নিরাপত্তা নিয়মে মকিংauth
সমর্থন করে, যা ইউনিট পরীক্ষাগুলিকে আরও সহজ করে তোলে। এছাড়াও, লাইব্রেরি কয়েকটি এমুলেটর-নির্দিষ্ট বৈশিষ্ট্য সমর্থন করে যেমন সমস্ত ডেটা সাফ করা, যেমন নীচে তালিকাভুক্ত করা হয়েছে। - এমুলেটররা ক্লায়েন্ট SDK-এর মাধ্যমে প্রদত্ত উত্পাদন ফায়ারবেস প্রমাণীকরণ টোকেনগুলিও গ্রহণ করবে এবং সেই অনুযায়ী নিয়মগুলি মূল্যায়ন করবে, যা ইন্টিগ্রেশন এবং ম্যানুয়াল পরীক্ষায় আপনার অ্যাপ্লিকেশনটিকে সরাসরি এমুলেটরগুলির সাথে সংযুক্ত করার অনুমতি দেয়৷
ডাটাবেস এমুলেটর এবং উত্পাদন মধ্যে পার্থক্য
- আপনাকে স্পষ্টভাবে একটি ডাটাবেস উদাহরণ তৈরি করতে হবে না। এমুলেটর স্বয়ংক্রিয়ভাবে অ্যাক্সেস করা কোনো ডাটাবেস উদাহরণ তৈরি করবে।
- প্রতিটি নতুন ডাটাবেস বন্ধ নিয়মের সাথে শুরু হয়, তাই নন-অ্যাডমিন ব্যবহারকারীরা পড়তে বা লিখতে সক্ষম হবে না।
- প্রতিটি অনুকরণ করা ডাটাবেস স্পার্ক পরিকল্পনার সীমা এবং কোটা প্রয়োগ করে (সবচেয়ে উল্লেখযোগ্যভাবে, এটি প্রতিটি উদাহরণকে 100টি সমবর্তী সংযোগে সীমাবদ্ধ করে)।
- যেকোনো ডাটাবেস স্ট্রিং
"owner"
কে অ্যাডমিন প্রমাণীকরণ টোকেন হিসাবে গ্রহণ করবে। - এমুলেটরগুলির বর্তমানে অন্যান্য ফায়ারবেস পণ্যগুলির সাথে কাজের ইন্টারঅ্যাকশন নেই৷ উল্লেখযোগ্যভাবে, সাধারণ ফায়ারবেস প্রমাণীকরণ প্রবাহ কাজ করে না। পরিবর্তে, আপনি
rules-unit-testing
লাইব্রেরিতেinitializeTestApp()
পদ্ধতিটি ব্যবহার করতে পারেন, যা একটিauth
ক্ষেত্র নেয়। এই পদ্ধতি ব্যবহার করে তৈরি করা Firebase অবজেক্টটি এমন আচরণ করে যেন এটি আপনার প্রদান করা সত্তা হিসাবে সফলভাবে প্রমাণীকৃত হয়েছে। আপনিnull
এ পাস করলে, এটি একটি অননুমোদিত ব্যবহারকারী হিসাবে আচরণ করবে (auth != null
নিয়ম ব্যর্থ হবে, উদাহরণস্বরূপ)।
রিয়েলটাইম ডেটাবেস এমুলেটরের সাথে ইন্টারঅ্যাক্ট করা
একটি প্রোডাকশন ফায়ারবেস রিয়েলটাইম ডেটাবেস উদাহরণ firebaseio.com
এর একটি সাবডোমেনে অ্যাক্সেসযোগ্য, এবং আপনি এইভাবে REST এপিআই অ্যাক্সেস করতে পারেন:
https://<database_name>.firebaseio.com/path/to/my/data.json
এমুলেটর স্থানীয়ভাবে চলে এবং localhost:9000
এ উপলব্ধ। একটি নির্দিষ্ট ডাটাবেস উদাহরণের সাথে ইন্টারঅ্যাক্ট করতে, আপনাকে ডাটাবেসের নাম নির্দিষ্ট করতে ns
ক্যোয়ারী প্যারামিটার ব্যবহার করতে হবে।
http://localhost:9000/path/to/my/data.json?ns=<database_name>
সংস্করণ 9 JavaScript SDK দিয়ে স্থানীয় ইউনিট পরীক্ষা চালান
Firebase এর সংস্করণ 9 JavaScript SDK এবং এর সংস্করণ 8 SDK উভয়ের সাথে একটি নিরাপত্তা নিয়ম ইউনিট পরীক্ষার লাইব্রেরি বিতরণ করে। লাইব্রেরি এপিআই উল্লেখযোগ্যভাবে ভিন্ন। আমরা v9 টেস্টিং লাইব্রেরির সুপারিশ করি, যেটি আরও সুবিন্যস্ত এবং এমুলেটরগুলির সাথে সংযোগ করার জন্য কম সেটআপের প্রয়োজন হয় এবং এইভাবে নিরাপদে উত্পাদন সংস্থানগুলির দুর্ঘটনাজনিত ব্যবহার এড়ানো যায়। পিছনের সামঞ্জস্যের জন্য, আমরা v8 টেস্টিং লাইব্রেরি উপলব্ধ করা চালিয়ে যাচ্ছি।
স্থানীয়ভাবে চলা এমুলেটরের সাথে ইন্টারঅ্যাক্ট করতে @firebase/rules-unit-testing
মডিউল ব্যবহার করুন। আপনি যদি টাইমআউট বা ECONNREFUSED
ত্রুটি পান, তাহলে এমুলেটরটি আসলে চলছে কিনা তা দুবার চেক করুন।
আমরা দৃঢ়ভাবে Node.js এর একটি সাম্প্রতিক সংস্করণ ব্যবহার করার পরামর্শ দিই যাতে আপনি async/await
notation ব্যবহার করতে পারেন। আপনি পরীক্ষা করতে চান এমন প্রায় সমস্ত আচরণের মধ্যে অ্যাসিঙ্ক্রোনাস ফাংশন জড়িত, এবং টেস্টিং মডিউলটি প্রতিশ্রুতি-ভিত্তিক কোডের সাথে কাজ করার জন্য ডিজাইন করা হয়েছে।
v9 রুলস ইউনিট টেস্টিং লাইব্রেরি সর্বদা এমুলেটর সম্পর্কে সচেতন এবং কখনই আপনার উত্পাদন সংস্থানগুলিকে স্পর্শ করে না।
আপনি v9 মডুলার আমদানি বিবৃতি ব্যবহার করে লাইব্রেরি আমদানি করেন। উদাহরণ স্বরূপ:
import {
assertFails,
assertSucceeds,
initializeTestEnvironment
} from "@firebase/rules-unit-testing"
// Use `const { … } = require("@firebase/rules-unit-testing")` if imports are not supported
// Or we suggest `const testing = require("@firebase/rules-unit-testing")` if necessary.
একবার আমদানি করা হলে, ইউনিট পরীক্ষা বাস্তবায়নের সাথে জড়িত:
-
initializeTestEnvironment
জন্য একটি কল সহ একটিRulesTestEnvironment
তৈরি এবং কনফিগার করা। - নিয়ম ট্রিগার না করে পরীক্ষার ডেটা সেট আপ করা, একটি সুবিধার পদ্ধতি ব্যবহার করে যা আপনাকে সাময়িকভাবে সেগুলিকে বাইপাস করতে দেয়,
RulesTestEnvironment.withSecurityRulesDisabled
। -
RulesTestEnvironment.cleanup()
বাRulesTestEnvironment.clearFirestore()
এর মতো পরীক্ষার ডেটা এবং পরিবেশ পরিষ্কার করতে কলের আগে/পরে পরীক্ষার স্যুট এবং প্রতি-পরীক্ষা সেট আপ করা। -
RulesTestEnvironment.authenticatedContext
এবংRulesTestEnvironment.unauthenticatedContext
ব্যবহার করে প্রমাণীকরণের অবস্থার অনুকরণ করে এমন পরীক্ষার ক্ষেত্রে প্রয়োগ করা।
সাধারণ পদ্ধতি এবং ইউটিলিটি ফাংশন
এছাড়াও মডুলার API ব্যবহার করে এমুলেটর-নির্দিষ্ট পরীক্ষা পদ্ধতি দেখুন।
initializeTestEnvironment() => RulesTestEnvironment
এই ফাংশনটি নিয়ম ইউনিট পরীক্ষার জন্য একটি পরীক্ষার পরিবেশ শুরু করে। পরীক্ষা সেটআপের জন্য প্রথমে এই ফাংশনটি কল করুন। সফল সম্পাদনের জন্য এমুলেটরগুলি চলমান থাকা প্রয়োজন৷
ফাংশন একটি TestEnvironmentConfig
সংজ্ঞায়িত একটি ঐচ্ছিক বস্তু গ্রহণ করে, যেটিতে একটি প্রকল্প আইডি এবং এমুলেটর কনফিগারেশন সেটিংস থাকতে পারে।
let testEnv = await initializeTestEnvironment({ projectId: "demo-project-1234", firestore: { rules: fs.readFileSync("firestore.rules", "utf8"), }, });
RulesTestEnvironment.authenticatedContext({ user_id: string, tokenOptions?: TokenOptions }) => RulesTestContext
এই পদ্ধতিটি একটি RulesTestContext
তৈরি করে, যা একটি প্রমাণীকৃত প্রমাণীকরণ ব্যবহারকারীর মতো আচরণ করে। প্রত্যাবর্তিত প্রসঙ্গের মাধ্যমে তৈরি করা অনুরোধগুলিতে একটি মক প্রমাণীকরণ টোকেন সংযুক্ত থাকবে। ঐচ্ছিকভাবে, প্রমাণীকরণ টোকেন পেলোডের জন্য কাস্টম দাবি বা ওভাররাইড সংজ্ঞায়িত করে একটি বস্তু পাস করুন।
initializeTestEnvironment
সাথে কনফিগার করা সহ কনফিগার করা যেকোনো এমুলেটর দৃষ্টান্ত অ্যাক্সেস করতে আপনার পরীক্ষায় প্রত্যাবর্তিত পরীক্ষার প্রসঙ্গ বস্তুটি ব্যবহার করুন।
// Assuming a Firestore app and the Firestore emulator for this example import { setDoc } from "firebase/firestore"; const alice = testEnv.authenticatedContext("alice", { … }); // Use the Firestore instance associated with this context await assertSucceeds(setDoc(alice.firestore(), '/users/alice'), { ... });
RulesTestEnvironment.unauthenticatedContext() => RulesTestContext
এই পদ্ধতিটি একটি RulesTestContext
তৈরি করে, যা একটি ক্লায়েন্টের মতো আচরণ করে যা প্রমাণীকরণের মাধ্যমে লগ ইন করা হয়নি। প্রত্যাবর্তিত প্রসঙ্গের মাধ্যমে তৈরি করা অনুরোধগুলিতে Firebase Auth টোকেন সংযুক্ত থাকবে না।
initializeTestEnvironment
সাথে কনফিগার করা সহ কনফিগার করা যেকোনো এমুলেটর দৃষ্টান্ত অ্যাক্সেস করতে আপনার পরীক্ষায় প্রত্যাবর্তিত পরীক্ষার প্রসঙ্গ বস্তুটি ব্যবহার করুন।
// Assuming a Cloud Storage app and the Storage emulator for this example import { getStorage, ref, deleteObject } from "firebase/storage"; const alice = testEnv.unauthenticatedContext(); // Use the Cloud Storage instance associated with this context const desertRef = ref(alice.storage(), 'images/desert.jpg'); await assertSucceeds(deleteObject(desertRef));
RulesTestEnvironment.withSecurityRulesDisabled()
এমন একটি প্রসঙ্গ সহ একটি পরীক্ষা সেটআপ ফাংশন চালান যা নিরাপত্তা বিধি অক্ষম করার মতো আচরণ করে৷
এই পদ্ধতিটি একটি কলব্যাক ফাংশন নেয়, যা নিরাপত্তা-বিধি-বাইপাস প্রসঙ্গ নেয় এবং একটি প্রতিশ্রুতি প্রদান করে। প্রতিশ্রুতি মীমাংসা / প্রত্যাখ্যান একবার প্রসঙ্গ ধ্বংস হবে.
RulesTestEnvironment.cleanup()
এই পদ্ধতিটি পরীক্ষার পরিবেশে তৈরি সমস্ত RulesTestContexts
ধ্বংস করে এবং অন্তর্নিহিত সংস্থানগুলি পরিষ্কার করে, একটি পরিষ্কার প্রস্থান করার অনুমতি দেয়।
এই পদ্ধতি কোনোভাবেই এমুলেটরদের অবস্থা পরিবর্তন করে না। পরীক্ষার মধ্যে ডেটা রিসেট করতে, অ্যাপ্লিকেশন এমুলেটর-নির্দিষ্ট পরিষ্কার ডেটা পদ্ধতি ব্যবহার করুন।
assertSucceeds(pr: Promise<any>)) => Promise<any>
এটি একটি টেস্ট কেস ইউটিলিটি ফাংশন।
ফাংশন দৃঢ়ভাবে বলে যে সরবরাহ করা প্রতিশ্রুতি একটি এমুলেটর অপারেশন মোড়ানো কোন নিরাপত্তা নিয়ম লঙ্ঘন ছাড়া সমাধান করা হবে.
await assertSucceeds(setDoc(alice.firestore(), '/users/alice'), { ... });
assertFails(pr: Promise<any>)) => Promise<any>
এটি একটি টেস্ট কেস ইউটিলিটি ফাংশন।
ফাংশন দৃঢ়ভাবে বলে যে একটি এমুলেটর অপারেশন মোড়ানো সরবরাহ করা প্রতিশ্রুতি নিরাপত্তা বিধি লঙ্ঘনের সাথে প্রত্যাখ্যান করা হবে।
await assertFails(setDoc(alice.firestore(), '/users/bob'), { ... });
এমুলেটর-নির্দিষ্ট পদ্ধতি
এছাড়াও মডুলার API ব্যবহার করে সাধারণ পরীক্ষার পদ্ধতি এবং ইউটিলিটি ফাংশন দেখুন।
ক্লাউড ফায়ারস্টোর
ক্লাউড ফায়ারস্টোর
RulesTestEnvironment.clearFirestore() => Promise<void>
এই পদ্ধতিটি Firestore ডাটাবেসের ডেটা সাফ করে যা Firestore এমুলেটরের জন্য কনফিগার করা projectId
অন্তর্গত।
RulesTestContext.firestore(settings?: Firestore.FirestoreSettings) => Firestore;
এই পদ্ধতিটি এই পরীক্ষার প্রসঙ্গের জন্য একটি Firestore উদাহরণ পায়। ফিরে আসা Firebase JS ক্লায়েন্ট SDK উদাহরণটি ক্লায়েন্ট SDK APIs (v9 মডুলার বা v9 কম্প্যাট) এর সাথে ব্যবহার করা যেতে পারে।
রিয়েলটাইম ডাটাবেস
রিয়েলটাইম ডাটাবেস
RulesTestEnvironment.clearDatabase() => Promise<void>
এই পদ্ধতিটি রিয়েলটাইম ডাটাবেসের ডেটা সাফ করে যা রিয়েলটাইম ডেটাবেস এমুলেটরের জন্য কনফিগার করা projectId
অন্তর্গত।
RulesTestContext.database(databaseURL?: Firestore.FirestoreSettings) => Firestore;
এই পরীক্ষার প্রসঙ্গের জন্য একটি রিয়েলটাইম ডেটাবেস উদাহরণ পান। ফিরে আসা Firebase JS ক্লায়েন্ট SDK দৃষ্টান্তটি ক্লায়েন্ট SDK API-এর সাথে ব্যবহার করা যেতে পারে (মডুলার বা নামস্থান, সংস্করণ 9 বা তার বেশি)। পদ্ধতিটি রিয়েলটাইম ডেটাবেস উদাহরণের একটি URL গ্রহণ করে। নির্দিষ্ট করা থাকলে, URL থেকে বের করা পরামিতি সহ নেমস্পেসের একটি এমুলেটেড সংস্করণের জন্য একটি উদাহরণ প্রদান করে।
মেঘ স্টোরেজ
মেঘ স্টোরেজ
RulesTestEnvironment.clearStorage() => Promise<void>
এই পদ্ধতিটি ক্লাউড স্টোরেজ এমুলেটরের জন্য কনফিগার করা projectId
এর অন্তর্গত স্টোরেজ বাকেটের বস্তু এবং মেটাডেটা সাফ করে।
RulesTestContext.storage(bucketUrl?: string) => Firebase Storage;
এই পদ্ধতিটি এমুলেটরের সাথে সংযোগ করার জন্য কনফিগার করা একটি স্টোরেজ উদাহরণ প্রদান করে। পদ্ধতিটি পরীক্ষার জন্য Firebase স্টোরেজ বাকেটের একটি gs://
url গ্রহণ করে। নির্দিষ্ট করা থাকলে, বালতি নামের একটি অনুকরণ করা সংস্করণের জন্য একটি স্টোরেজ উদাহরণ প্রদান করে।
v8 JavaScript SDK দিয়ে স্থানীয় ইউনিট পরীক্ষা চালান
এমুলেটরের সাথে ইন্টারফেস করতে Firebase টেস্ট SDK দ্বারা ব্যবহৃত পদ্ধতিগুলি দেখতে একটি পণ্য নির্বাচন করুন৷
ক্লাউড ফায়ারস্টোর
initializeTestApp({ projectId: string, auth: Object }) => FirebaseApp
এই পদ্ধতিটি একটি প্রারম্ভিক ফায়ারবেস অ্যাপ প্রদান করে যা প্রজেক্ট আইডি এবং অপশনে উল্লেখ করা প্রমাণ ভেরিয়েবলের সাথে সম্পর্কিত। পরীক্ষায় ব্যবহার করার জন্য একটি নির্দিষ্ট ব্যবহারকারী হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
firebase.initializeTestApp({ projectId: "my-test-project", auth: { uid: "alice", email: "alice@example.com" } });
initializeAdminApp({ projectId: string }) => FirebaseApp
এই পদ্ধতিটি একটি প্রারম্ভিক অ্যাডমিন ফায়ারবেস অ্যাপ প্রদান করে। এই অ্যাপটি রিড এবং রাইট করার সময় নিরাপত্তা বিধিগুলিকে বাইপাস করে৷ পরীক্ষার জন্য রাজ্য সেট করতে প্রশাসক হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
firebase.initializeAdminApp({ projectId: "my-test-project" });
apps() => [FirebaseApp]
এই পদ্ধতিটি বর্তমানে সমস্ত প্রাথমিক পরীক্ষা এবং অ্যাডমিন অ্যাপ রিটার্ন করে। পরীক্ষার মধ্যে বা পরে অ্যাপগুলি পরিষ্কার করতে এটি ব্যবহার করুন।
Promise.all(firebase.apps().map(app => app.delete()))
loadFirestoreRules({ projectId: string, rules: Object }) => Promise
এই পদ্ধতি স্থানীয়ভাবে চলমান ডাটাবেসে নিয়ম পাঠায়। এটি এমন একটি বস্তু নেয় যা নিয়মগুলিকে একটি স্ট্রিং হিসাবে নির্দিষ্ট করে। আপনার ডাটাবেসের নিয়ম সেট করতে এই পদ্ধতিটি ব্যবহার করুন।
firebase.loadFirestoreRules({ projectId: "my-test-project", rules: fs.readFileSync("/path/to/firestore.rules", "utf8") });
assertFails(pr: Promise) => Promise
এই পদ্ধতিটি একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে প্রত্যাখ্যান করা হয় বা ইনপুট প্রত্যাখ্যান করা হলে এটি সফল হয়। একটি ডাটাবেস পড়া বা লিখতে ব্যর্থ হলে এটা নিশ্চিত করতে ব্যবহার করুন।
firebase.assertFails(app.firestore().collection("private").doc("super-secret-document").get());
assertSucceeds(pr: Promise) => Promise
এই পদ্ধতিটি একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে সফল হয় এবং ইনপুট প্রত্যাখ্যান করা হলে প্রত্যাখ্যাত হয়। একটি ডাটাবেস পড়া বা লিখতে সফল হয় কিনা তা নিশ্চিত করতে এটি ব্যবহার করুন।
firebase.assertSucceeds(app.firestore().collection("public").doc("test-document").get());
clearFirestoreData({ projectId: string }) => Promise
এই পদ্ধতিটি স্থানীয়ভাবে চলমান Firestore উদাহরণে একটি নির্দিষ্ট প্রকল্পের সাথে সম্পর্কিত সমস্ত ডেটা সাফ করে। পরীক্ষার পরে পরিষ্কার করার জন্য এই পদ্ধতিটি ব্যবহার করুন।
firebase.clearFirestoreData({ projectId: "my-test-project" });
রিয়েলটাইম ডাটাবেস
রিয়েলটাইম ডাটাবেস
initializeTestApp({ databaseName: string, auth: Object }) => FirebaseApp
পরীক্ষায় ব্যবহার করার জন্য একটি নির্দিষ্ট ব্যবহারকারী হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
বিকল্পগুলিতে নির্দিষ্ট করা ডাটাবেসের নাম এবং প্রমাণীকরণ পরিবর্তনশীল ওভাররাইডের সাথে সম্পর্কিত একটি প্রাথমিক ফায়ারবেস অ্যাপ প্রদান করে।
firebase.initializeTestApp({
databaseName: "my-database",
auth: { uid: "alice" }
});
initializeAdminApp({ databaseName: string }) => FirebaseApp
পরীক্ষার জন্য রাজ্য সেট আপ করতে প্রশাসক হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
বিকল্পগুলিতে নির্দিষ্ট করা ডাটাবেসের নামের সাথে সম্পর্কিত একটি প্রাথমিক অ্যাডমিন ফায়ারবেস অ্যাপ প্রদান করে। ডাটাবেসে পড়ার এবং লেখার সময় এই অ্যাপটি নিরাপত্তা নিয়মগুলিকে বাইপাস করে৷
firebase.initializeAdminApp({ databaseName: "my-database" });
loadDatabaseRules({ databaseName: string, rules: Object }) => Promise
আপনার ডাটাবেসের নিয়ম সেট করতে এটি ব্যবহার করুন।
স্থানীয়ভাবে চলমান ডাটাবেসে নিয়ম পাঠায়। একটি অপশন অবজেক্ট নেয় যা আপনার "ডাটাবেসের নাম" এবং আপনার "নিয়ম" স্ট্রিং হিসাবে নির্দিষ্ট করে।
firebase
.loadDatabaseRules({
databaseName: "my-database",
rules: "{'rules': {'.read': false, '.write': false}}"
});
apps() => [FirebaseApp]
বর্তমানে শুরু করা সমস্ত পরীক্ষা এবং প্রশাসক অ্যাপ প্রদান করে।
পরীক্ষার মধ্যে বা পরে অ্যাপগুলি পরিষ্কার করতে এটি ব্যবহার করুন (মনে রাখবেন যে সক্রিয় শ্রোতাদের সাথে শুরু করা অ্যাপগুলি জাভাস্ক্রিপ্ট থেকে প্রস্থান করতে বাধা দেয়):
Promise.all(firebase.apps().map(app => app.delete()))
assertFails(pr: Promise) => Promise
একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে প্রত্যাখ্যাত হয় এবং ইনপুট প্রত্যাখ্যান হলে সফল হয়।
একটি ডাটাবেস পড়তে বা লিখতে ব্যর্থ হয় তা নিশ্চিত করতে এটি ব্যবহার করুন:
firebase.assertFails(app.database().ref("secret").once("value"));
assertSucceeds(pr: Promise) => Promise
একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে সফল হয় এবং ইনপুট প্রত্যাখ্যাত হলে প্রত্যাখ্যাত হয়।
একটি ডাটাবেস পড়া বা লেখা সফল হয়েছে তা নিশ্চিত করতে এটি ব্যবহার করুন:
firebase.assertSucceeds(app.database().ref("public").once("value"));
মেঘ স্টোরেজ
মেঘ স্টোরেজ
initializeTestApp({ storageBucket: string, auth: Object }) => FirebaseApp
পরীক্ষায় ব্যবহার করার জন্য একটি নির্দিষ্ট ব্যবহারকারী হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
স্টোরেজ বাকেটের নাম এবং বিকল্পগুলিতে নির্দিষ্ট করা প্রমাণীকরণ পরিবর্তনশীল ওভাররাইডের সাথে সম্পর্কিত একটি প্রাথমিক ফায়ারবেস অ্যাপ প্রদান করে।
firebase.initializeTestApp({
storageBucket: "my-bucket",
auth: { uid: "alice" }
});
initializeAdminApp({ storageBucket: string }) => FirebaseApp
পরীক্ষার জন্য রাজ্য সেট আপ করতে প্রশাসক হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
বিকল্পগুলিতে নির্দিষ্ট করা স্টোরেজ বাকেট নামের সাথে সম্পর্কিত একটি প্রাথমিক অ্যাডমিন ফায়ারবেস অ্যাপ প্রদান করে। এই অ্যাপটি বালতিতে পড়ার এবং লেখার সময় নিরাপত্তা নিয়মগুলিকে বাইপাস করে৷
firebase.initializeAdminApp({ storageBucket: "my-bucket" });
loadStorageRules({ storageBucket: string, rules: Object }) => Promise
আপনার স্টোরেজ বাকেটের নিয়ম সেট করতে এটি ব্যবহার করুন।
স্থানীয়ভাবে পরিচালিত স্টোরেজ বালতিতে নিয়ম পাঠায়। একটি বিকল্প অবজেক্ট নেয় যা আপনার "storageBucket" এবং আপনার "নিয়ম" স্ট্রিং হিসাবে নির্দিষ্ট করে।
firebase
.loadStorageRules({
storageBucket: "my-bucket",
rules: fs.readFileSync("/path/to/storage.rules", "utf8")
});
apps() => [FirebaseApp]
বর্তমানে শুরু করা সমস্ত পরীক্ষা এবং প্রশাসক অ্যাপ প্রদান করে।
পরীক্ষার মধ্যে বা পরে অ্যাপগুলি পরিষ্কার করতে এটি ব্যবহার করুন (মনে রাখবেন যে সক্রিয় শ্রোতাদের সাথে শুরু করা অ্যাপগুলি জাভাস্ক্রিপ্ট থেকে প্রস্থান করতে বাধা দেয়):
Promise.all(firebase.apps().map(app => app.delete()))
assertFails(pr: Promise) => Promise
একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে প্রত্যাখ্যাত হয় এবং ইনপুট প্রত্যাখ্যান হলে সফল হয়।
একটি স্টোরেজ বালতি পড়তে বা লিখতে ব্যর্থ হয় তা নিশ্চিত করতে এটি ব্যবহার করুন:
firebase.assertFails(app.storage().ref("letters/private.doc").getMetadata());
assertSucceeds(pr: Promise) => Promise
একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে সফল হয় এবং ইনপুট প্রত্যাখ্যাত হলে প্রত্যাখ্যাত হয়।
একটি স্টোরেজ বালতি পড়া বা লেখা সফল হয়েছে তা নিশ্চিত করতে এটি ব্যবহার করুন:
firebase.assertFails(app.storage().ref("images/cat.png").getMetadata());
JS SDK v8 এর জন্য RUT লাইব্রেরি API
এমুলেটরের সাথে ইন্টারফেস করতে Firebase টেস্ট SDK দ্বারা ব্যবহৃত পদ্ধতিগুলি দেখতে একটি পণ্য নির্বাচন করুন৷
ক্লাউড ফায়ারস্টোর
ক্লাউড ফায়ারস্টোর
initializeTestApp({ projectId: string, auth: Object }) => FirebaseApp
এই পদ্ধতিটি একটি প্রারম্ভিক ফায়ারবেস অ্যাপ প্রদান করে যা প্রজেক্ট আইডি এবং অপশনে উল্লেখ করা প্রমাণ ভেরিয়েবলের সাথে সম্পর্কিত। পরীক্ষায় ব্যবহার করার জন্য একটি নির্দিষ্ট ব্যবহারকারী হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
firebase.initializeTestApp({ projectId: "my-test-project", auth: { uid: "alice", email: "alice@example.com" } });
initializeAdminApp({ projectId: string }) => FirebaseApp
এই পদ্ধতিটি একটি প্রারম্ভিক অ্যাডমিন ফায়ারবেস অ্যাপ প্রদান করে। এই অ্যাপটি রিড এবং রাইট করার সময় নিরাপত্তা বিধিগুলিকে বাইপাস করে৷ পরীক্ষার জন্য রাজ্য সেট করতে প্রশাসক হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
firebase.initializeAdminApp({ projectId: "my-test-project" });
apps() => [FirebaseApp]
এই পদ্ধতিটি বর্তমানে সমস্ত প্রাথমিক পরীক্ষা এবং অ্যাডমিন অ্যাপ রিটার্ন করে। পরীক্ষার মধ্যে বা পরে অ্যাপগুলি পরিষ্কার করতে এটি ব্যবহার করুন।
Promise.all(firebase.apps().map(app => app.delete()))
loadFirestoreRules({ projectId: string, rules: Object }) => Promise
এই পদ্ধতি স্থানীয়ভাবে চলমান ডাটাবেসে নিয়ম পাঠায়। এটি এমন একটি বস্তু নেয় যা নিয়মগুলিকে একটি স্ট্রিং হিসাবে নির্দিষ্ট করে। আপনার ডাটাবেসের নিয়ম সেট করতে এই পদ্ধতিটি ব্যবহার করুন।
firebase.loadFirestoreRules({ projectId: "my-test-project", rules: fs.readFileSync("/path/to/firestore.rules", "utf8") });
assertFails(pr: Promise) => Promise
এই পদ্ধতিটি একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে প্রত্যাখ্যান করা হয় বা ইনপুট প্রত্যাখ্যান করা হলে এটি সফল হয়। একটি ডাটাবেস পড়া বা লিখতে ব্যর্থ হলে এটা নিশ্চিত করতে ব্যবহার করুন।
firebase.assertFails(app.firestore().collection("private").doc("super-secret-document").get());
assertSucceeds(pr: Promise) => Promise
এই পদ্ধতিটি একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে সফল হয় এবং ইনপুট প্রত্যাখ্যান করা হলে প্রত্যাখ্যাত হয়। একটি ডাটাবেস পড়া বা লিখতে সফল হয় কিনা তা নিশ্চিত করতে এটি ব্যবহার করুন।
firebase.assertSucceeds(app.firestore().collection("public").doc("test-document").get());
clearFirestoreData({ projectId: string }) => Promise
এই পদ্ধতিটি স্থানীয়ভাবে চলমান Firestore উদাহরণে একটি নির্দিষ্ট প্রকল্পের সাথে সম্পর্কিত সমস্ত ডেটা সাফ করে। পরীক্ষার পরে পরিষ্কার করার জন্য এই পদ্ধতিটি ব্যবহার করুন।
firebase.clearFirestoreData({ projectId: "my-test-project" });
রিয়েলটাইম ডাটাবেস
রিয়েলটাইম ডাটাবেস
initializeTestApp({ databaseName: string, auth: Object }) => FirebaseApp
পরীক্ষায় ব্যবহার করার জন্য একটি নির্দিষ্ট ব্যবহারকারী হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
বিকল্পগুলিতে নির্দিষ্ট করা ডাটাবেসের নাম এবং প্রমাণীকরণ পরিবর্তনশীল ওভাররাইডের সাথে সম্পর্কিত একটি প্রাথমিক ফায়ারবেস অ্যাপ প্রদান করে।
firebase.initializeTestApp({
databaseName: "my-database",
auth: { uid: "alice" }
});
initializeAdminApp({ databaseName: string }) => FirebaseApp
পরীক্ষার জন্য রাজ্য সেট আপ করতে প্রশাসক হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
বিকল্পগুলিতে নির্দিষ্ট করা ডাটাবেসের নামের সাথে সম্পর্কিত একটি প্রাথমিক অ্যাডমিন ফায়ারবেস অ্যাপ প্রদান করে। ডাটাবেসে পড়ার এবং লেখার সময় এই অ্যাপটি নিরাপত্তা নিয়মগুলিকে বাইপাস করে৷
firebase.initializeAdminApp({ databaseName: "my-database" });
loadDatabaseRules({ databaseName: string, rules: Object }) => Promise
আপনার ডাটাবেসের নিয়ম সেট করতে এটি ব্যবহার করুন।
স্থানীয়ভাবে চলমান ডাটাবেসে নিয়ম পাঠায়। একটি অপশন অবজেক্ট নেয় যা আপনার "ডাটাবেসের নাম" এবং আপনার "নিয়ম" স্ট্রিং হিসাবে নির্দিষ্ট করে।
firebase
.loadDatabaseRules({
databaseName: "my-database",
rules: "{'rules': {'.read': false, '.write': false}}"
});
apps() => [FirebaseApp]
বর্তমানে শুরু করা সমস্ত পরীক্ষা এবং প্রশাসক অ্যাপ প্রদান করে।
পরীক্ষার মধ্যে বা পরে অ্যাপগুলি পরিষ্কার করতে এটি ব্যবহার করুন (মনে রাখবেন যে সক্রিয় শ্রোতাদের সাথে শুরু করা অ্যাপগুলি জাভাস্ক্রিপ্ট থেকে প্রস্থান করতে বাধা দেয়):
Promise.all(firebase.apps().map(app => app.delete()))
assertFails(pr: Promise) => Promise
একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে প্রত্যাখ্যাত হয় এবং ইনপুট প্রত্যাখ্যান হলে সফল হয়।
একটি ডাটাবেস পড়তে বা লিখতে ব্যর্থ হয় তা নিশ্চিত করতে এটি ব্যবহার করুন:
firebase.assertFails(app.database().ref("secret").once("value"));
assertSucceeds(pr: Promise) => Promise
একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে সফল হয় এবং ইনপুট প্রত্যাখ্যাত হলে প্রত্যাখ্যাত হয়।
একটি ডাটাবেস পড়া বা লেখা সফল হয়েছে তা নিশ্চিত করতে এটি ব্যবহার করুন:
firebase.assertSucceeds(app.database().ref("public").once("value"));
মেঘ স্টোরেজ
মেঘ স্টোরেজ
initializeTestApp({ storageBucket: string, auth: Object }) => FirebaseApp
পরীক্ষায় ব্যবহার করার জন্য একটি নির্দিষ্ট ব্যবহারকারী হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
স্টোরেজ বাকেটের নাম এবং বিকল্পগুলিতে নির্দিষ্ট করা প্রমাণীকরণ পরিবর্তনশীল ওভাররাইডের সাথে সম্পর্কিত একটি প্রাথমিক ফায়ারবেস অ্যাপ প্রদান করে।
firebase.initializeTestApp({
storageBucket: "my-bucket",
auth: { uid: "alice" }
});
initializeAdminApp({ storageBucket: string }) => FirebaseApp
পরীক্ষার জন্য রাজ্য সেট আপ করতে প্রশাসক হিসাবে প্রমাণীকৃত একটি অ্যাপ তৈরি করতে এটি ব্যবহার করুন।
বিকল্পগুলিতে নির্দিষ্ট করা স্টোরেজ বাকেট নামের সাথে সম্পর্কিত একটি প্রাথমিক অ্যাডমিন ফায়ারবেস অ্যাপ প্রদান করে। এই অ্যাপটি বালতিতে পড়ার এবং লেখার সময় নিরাপত্তা নিয়মগুলিকে বাইপাস করে৷
firebase.initializeAdminApp({ storageBucket: "my-bucket" });
loadStorageRules({ storageBucket: string, rules: Object }) => Promise
আপনার স্টোরেজ বাকেটের নিয়ম সেট করতে এটি ব্যবহার করুন।
স্থানীয়ভাবে পরিচালিত স্টোরেজ বালতিতে নিয়ম পাঠায়। একটি বিকল্প অবজেক্ট নেয় যা আপনার "storageBucket" এবং আপনার "নিয়ম" স্ট্রিং হিসাবে নির্দিষ্ট করে।
firebase
.loadStorageRules({
storageBucket: "my-bucket",
rules: fs.readFileSync("/path/to/storage.rules", "utf8")
});
apps() => [FirebaseApp]
বর্তমানে শুরু করা সমস্ত পরীক্ষা এবং প্রশাসক অ্যাপ প্রদান করে।
পরীক্ষার মধ্যে বা পরে অ্যাপগুলি পরিষ্কার করতে এটি ব্যবহার করুন (মনে রাখবেন যে সক্রিয় শ্রোতাদের সাথে শুরু করা অ্যাপগুলি জাভাস্ক্রিপ্ট থেকে প্রস্থান করতে বাধা দেয়):
Promise.all(firebase.apps().map(app => app.delete()))
assertFails(pr: Promise) => Promise
একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে প্রত্যাখ্যাত হয় এবং ইনপুট প্রত্যাখ্যান হলে সফল হয়।
একটি স্টোরেজ বালতি পড়তে বা লিখতে ব্যর্থ হয় তা নিশ্চিত করতে এটি ব্যবহার করুন:
firebase.assertFails(app.storage().ref("letters/private.doc").getMetadata());
assertSucceeds(pr: Promise) => Promise
একটি প্রতিশ্রুতি প্রদান করে যা ইনপুট সফল হলে সফল হয় এবং ইনপুট প্রত্যাখ্যাত হলে প্রত্যাখ্যাত হয়।
একটি স্টোরেজ বালতি পড়া বা লেখা সফল হয়েছে তা নিশ্চিত করতে এটি ব্যবহার করুন:
firebase.assertFails(app.storage().ref("images/cat.png").getMetadata());