ইউনিট পরীক্ষা তৈরি করুন

ফায়ারবেস স্থানীয় এমুলেটর স্যুট আপনার অ্যাপের বৈশিষ্ট্য এবং আচরণ সম্পূর্ণরূপে যাচাই করা সহজ করে তোলে। এটি আপনার ফায়ারবেস নিরাপত্তা নিয়ম কনফিগারেশন যাচাই করার জন্য একটি দুর্দান্ত টুল। স্থানীয় পরিবেশে ইউনিট পরীক্ষা চালানো এবং স্বয়ংক্রিয় করতে Firebase এমুলেটর ব্যবহার করুন। এই নথিতে বর্ণিত পদ্ধতিগুলি আপনাকে সাহায্য করবে যখন আপনি আপনার অ্যাপের জন্য ইউনিট পরীক্ষাগুলি তৈরি এবং স্বয়ংক্রিয়ভাবে তৈরি করবেন যা আপনার নিয়মগুলিকে যাচাই করে৷

আপনি যদি ইতিমধ্যেই না করে থাকেন তাহলে Firebase এমুলেটর সেট আপ করুন

আপনি এমুলেটর চালানোর আগে

আপনি এমুলেটর ব্যবহার শুরু করার আগে, নিম্নলিখিতগুলি মনে রাখবেন:

  • এমুলেটর প্রাথমিকভাবে আপনার firebase.json ফাইলের firestore.rules বা 'storage.rules' ক্ষেত্রে নির্দিষ্ট নিয়ম লোড করবে। যদি ফাইলটি বিদ্যমান না থাকে এবং আপনি নীচে বর্ণিত loadFirestoreRules বা 'loadStorageRules' পদ্ধতি ব্যবহার না করেন, তাহলে এমুলেটর সমস্ত প্রকল্পকে উন্মুক্ত নিয়ম হিসাবে বিবেচনা করে।
  • যদিও বেশিরভাগ ফায়ারবেস 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,
  RulesTestEnvironment,
} 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.

একবার আমদানি করা হলে, ইউনিট পরীক্ষা বাস্তবায়নের সাথে জড়িত:

  • RulesTestEnvironment শুরু করার জন্য একটি কলের সাথে একটি নিয়ম টেস্ট পরিবেশ তৈরি এবং কনফিগার initializeTestEnvironment
  • নিয়ম ট্রিগার না করে পরীক্ষার ডেটা সেট আপ করা, একটি সুবিধার পদ্ধতি ব্যবহার করে যা আপনাকে সাময়িকভাবে সেগুলিকে বাইপাস করতে দেয়, RulesTestEnvironment.withSecurityRulesDisabled
  • RulesTestEnvironment.cleanup() বা RulesTestEnvironment.clearFirestore() এর মতো পরীক্ষার ডেটা এবং পরিবেশ পরিষ্কার করতে কলের আগে/পরে পরীক্ষার স্যুট এবং প্রতি-পরীক্ষা সেট আপ করা।
  • RulesTestEnvironment.authenticatedContext এবং RulesTestEnvironment.unauthenticatedContext ব্যবহার করে প্রমাণীকরণের অবস্থার অনুকরণ করে এমন পরীক্ষার ক্ষেত্রে প্রয়োগ করা।

সাধারণ পদ্ধতি এবং ইউটিলিটি ফাংশন

এছাড়াও v9 SDK-এ এমুলেটর-নির্দিষ্ট পরীক্ষা পদ্ধতি দেখুন।

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 প্রমাণীকরণ টোকেন সংযুক্ত থাকবে না।

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'), { ... });

এমুলেটর-নির্দিষ্ট পদ্ধতি

এছাড়াও v9 SDK-এ সাধারণ পরীক্ষা পদ্ধতি এবং ইউটিলিটি ফাংশন দেখুন।

ক্লাউড ফায়ারস্টোর

ক্লাউড ফায়ারস্টোর

RulesTestEnvironment.clearFirestore() => Promise<void>

এই পদ্ধতিটি Firestore ডাটাবেসের ডেটা সাফ করে যা projectId এমুলেটরের জন্য কনফিগার করা 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 APIs (v9 মডুলার বা v9 কম্প্যাট) এর সাথে ব্যবহার করা যেতে পারে। পদ্ধতিটি রিয়েলটাইম ডেটাবেস উদাহরণের একটি URL গ্রহণ করে। নির্দিষ্ট করা থাকলে, URL থেকে বের করা পরামিতি সহ নামস্থানের একটি অনুকরণ করা সংস্করণের জন্য একটি উদাহরণ প্রদান করে।

মেঘ স্টোরেজ

মেঘ স্টোরেজ

RulesTestEnvironment.clearStorage() => Promise<void>

এই পদ্ধতিটি ক্লাউড স্টোরেজ এমুলেটরের জন্য কনফিগার করা ProjectId-এর অন্তর্গত স্টোরেজ projectId বস্তু এবং মেটাডেটা সাফ করে।

RulesTestContext.storage(bucketUrl?: string) => Firebase Storage;

এই পদ্ধতিটি এমুলেটরের সাথে সংযোগ করার জন্য কনফিগার করা একটি স্টোরেজ উদাহরণ প্রদান করে। পদ্ধতিটি পরীক্ষার জন্য Firebase স্টোরেজ gs:// url গ্রহণ করে। নির্দিষ্ট করা থাকলে, বালতি নামের একটি অনুকরণ করা সংস্করণের জন্য একটি স্টোরেজ উদাহরণ প্রদান করে।

v8 JavaScript SDK দিয়ে স্থানীয় ইউনিট পরীক্ষা চালান

এমুলেটরের সাথে ইন্টারফেস করার জন্য ফায়ারবেস টেস্ট 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

এমুলেটরের সাথে ইন্টারফেস করার জন্য ফায়ারবেস টেস্ট 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());