স্মার্ট হোম ডিবাগ করা হচ্ছে

1. আপনি শুরু করার আগে

ইন্টারনেট অফ থিংস (IoT) বিকাশকারী হিসাবে, আপনি স্মার্ট হোম অ্যাকশন তৈরি করতে পারেন যা আপনার ব্যবহারকারীদের Google হোম অ্যাপে স্পর্শ নিয়ন্ত্রণ এবং Google সহকারীর সাথে ভয়েস কমান্ডের মাধ্যমে তাদের ডিভাইসগুলি নিয়ন্ত্রণ করার ক্ষমতা দেয়।

a4657871181b5ad2.gif

স্মার্ট হোম অ্যাকশনের জন্য ডিবাগিং টুল শেখা Google Assistant-এর সাথে প্রোডাকশন কোয়ালিটি ইন্টিগ্রেশন তৈরি করার জন্য একটি গুরুত্বপূর্ণ ধাপ। সহজে নিরীক্ষণ এবং ডিবাগিং সহজতর করার জন্য, Google ক্লাউড প্ল্যাটফর্ম (GCP) মেট্রিক্স এবং লগিং এবং স্মার্ট হোমের জন্য টেস্ট স্যুট আপনার অ্যাকশনগুলির সমস্যাগুলি সনাক্ত করতে এবং সমাধান করতে আপনাকে সহায়তা করার জন্য উপলব্ধ।

পূর্বশর্ত

আপনি কি নির্মাণ করবেন

এই কোডল্যাবে, আপনি 2টি ত্রুটি সহ একটি স্মার্ট হোম অ্যাকশন স্থাপন করবেন এবং এটিকে অ্যাসিস্ট্যান্টের সাথে সংযুক্ত করবেন, তারপর স্মার্ট হোম এবং Google ক্লাউড প্ল্যাটফর্ম (GCP) মেট্রিক্স এবং লগিংয়ের জন্য টেস্ট স্যুটের মাধ্যমে অ্যাকশনের ত্রুটিগুলি ডিবাগ করবেন।

আপনি কি শিখবেন

  • কিভাবে GCP মেট্রিক্স এবং লগিং ব্যবহার করবেন উৎপাদন সমস্যা চিহ্নিত করতে এবং সমাধান করতে
  • কার্যকরী এবং API সমস্যাগুলি সনাক্ত করতে স্মার্ট হোমের জন্য টেস্ট স্যুট কীভাবে ব্যবহার করবেন

আপনি কি প্রয়োজন হবে

2. ত্রুটিপূর্ণ অ্যাপ চালান

সোর্স কোড পান

আপনার ডেভেলপমেন্ট মেশিনে এই কোডল্যাবের নমুনা ডাউনলোড করতে নিম্নলিখিত লিঙ্কে ক্লিক করুন:

...অথবা আপনি কমান্ড লাইন থেকে GitHub সংগ্রহস্থল ক্লোন করতে পারেন:

$ git clone https://github.com/google-home/smarthome-debug.git

প্রকল্প সম্পর্কে

ওয়াশার অ্যাপটিতে নিম্নলিখিত সাবডিরেক্টরি রয়েছে:

  • public : স্মার্ট ওয়াশারের অবস্থা সহজেই নিয়ন্ত্রণ এবং নিরীক্ষণ করার জন্য একটি ফ্রন্টএন্ড UI।
  • functions : একটি সম্পূর্ণরূপে বাস্তবায়িত ক্লাউড পরিষেবা যা ফায়ারবেস এবং ফায়ারবেস রিয়েলটাইম ডেটাবেসের জন্য ক্লাউড ফাংশনগুলির সাথে স্মার্ট ওয়াশার পরিচালনা করে৷

ফায়ারবেসের সাথে সংযোগ করুন

আপনার ডেভেলপমেন্ট মেশিনে টার্মিনাল খুলুন। washer-faulty ডিরেক্টরিতে নেভিগেট করুন, তারপর Google অ্যাসিস্ট্যান্ট কোডল্যাবে স্মার্ট হোম ডিভাইসে সংযুক্ত আপনার অ্যাকশন প্রকল্পের সাথে Firebase CLI সেট আপ করুন:

$ cd washer-faulty
$ firebase use <project-id>

ফায়ারবেসে স্থাপন করুন

functions ফোল্ডারে নেভিগেট করুন এবং npm.

$ cd functions
$ npm install

দ্রষ্টব্য: আপনি যদি নীচের বার্তাটি দেখতে পান, আপনি উপেক্ষা করে এগিয়ে যেতে পারেন৷ সতর্কতাটি কিছু পুরানো নির্ভরতার কারণে এবং আপনি এখানে আরো বিস্তারিত জানতে পারেন।

found 5 high severity vulnerabilities
  run `npm audit fix` to fix them, or `npm audit` for details

এখন আপনি নির্ভরতাগুলি ইনস্টল করেছেন এবং আপনার প্রকল্পটি কনফিগার করেছেন, আপনি ত্রুটিযুক্ত ওয়াশার অ্যাপ স্থাপন করতে প্রস্তুত৷

$ firebase deploy

এটি হল কনসোল আউটপুট যা আপনাকে দেখতে হবে:

...

✔ Deploy complete!

Project Console: https://console.firebase.google.com/project/<project-id>/overview
Hosting URL: https://<project-id>.firebaseapp.com

হোমগ্রাফ আপডেট করুন

ওয়েব অ্যাপ দেখতে আপনার ব্রাউজারে হোস্টিং URL খুলুন ( https://<project-id>.firebaseapp.com )। ওয়েব UI-তে, রিফ্রেশ ক্লিক করুন ae8d3b25777a5e30.png ত্রুটিযুক্ত ওয়াশার অ্যাপ থেকে সাম্প্রতিক ডিভাইস মেটাডেটা সহ অনুরোধ সিঙ্কের মাধ্যমে হোমগ্রাফ আপডেট করার বোতাম:

6f2b1344179977cf.png

Google Home অ্যাপটি খুলুন এবং যাচাই করুন যে আপনি Faulty Washer নামের ওয়াশার ডিভাইসটি দেখতে পাচ্ছেন।

e357de6a7faff925.png

3. আপনার ক্রিয়া পরীক্ষা করুন

আপনি আপনার প্রকল্প স্থাপন করার পরে, পরীক্ষা করুন যে আপনার অ্যাকশন ওয়াশার নিয়ন্ত্রণ করে।

ওয়াশার পরীক্ষা করুন

আপনি যখন আপনার ফোনের মাধ্যমে নিম্নলিখিত ভয়েস কমান্ডগুলির মধ্যে যেকোনো একটি চেষ্টা করেন তখন মান পরিবর্তন পরীক্ষা করুন:

"ওহে গুগল, আমার ওয়াশার চালু করুন।"

"ওহে গুগল, আমার ওয়াশার শুরু করুন।"

"ওহে গুগল, আমার ওয়াশার থামান।"

"ওহে গুগল, আমার ওয়াশার আবার শুরু কর।"

"ওহে গুগল, আমার ওয়াশার বন্ধ করুন।"

আপনি লক্ষ্য করবেন যে আপনি ওয়াশারটি বিরতি / পুনরায় চালু করার সময় সহকারী প্রতিক্রিয়া জানায় যে ভয়েসের মাধ্যমে কিছু ভুল হয়েছে:

"দুঃখিত, আমি <project display name> এ পৌঁছাতে পারিনি।"

এই সমস্যাটি ডিবাগ করতে, আপনাকে প্রথমে ত্রুটিটি সংকুচিত করতে এবং মূল কারণ সনাক্ত করতে আরও তথ্যের প্রয়োজন৷

স্মার্টহোম অ্যানালিটিক্স ড্যাশবোর্ড

ত্রুটিগুলি পরিদর্শন করার একটি ভাল জায়গা হল স্মার্টহোম অ্যানালিটিক্স ড্যাশবোর্ড , যা আপনার ক্লাউড পূরণের জন্য ব্যবহার এবং স্বাস্থ্য মেট্রিক্সের চার্টগুলিকে একত্রিত করে:

  • ব্যবহারের মেট্রিক্স আপনার স্মার্ট হোম অ্যাকশনের ব্যবহারের প্রবণতাকে প্রতিফলিত করে, যার মধ্যে দৈনিক সক্রিয় ব্যবহারকারীর সংখ্যা এবং আপনার পূরণের জন্য মোট অনুরোধের সংখ্যা অন্তর্ভুক্ত।
  • হেলথ মেট্রিক্স আপনাকে আপনার স্মার্ট হোম অ্যাকশনে অসঙ্গতি ঘটছে তা নিরীক্ষণ করতে সাহায্য করে, অনুরোধের বিলম্ব, সাফল্যের শতাংশ এবং ত্রুটির ভাঙ্গন কভার করে।

ত্রুটির কারণ সংকুচিত করতে, প্রকল্প ড্যাশবোর্ড অ্যাক্সেস করতে নীচের পদক্ষেপগুলি অনুসরণ করুন৷

  1. অ্যাকশন কনসোলে , প্রজেক্ট পৃষ্ঠায় যান।
  2. আপনার স্মার্ট হোম প্রকল্প নির্বাচন করুন.
  3. অ্যানালিটিক্স ট্যাবটি বেছে নিন এবং Google ক্লাউড প্ল্যাটফর্মে যান ক্লিক করুন।

b1735bbe11a7aff8.png

  1. এটি আপনাকে Google ক্লাউডে আপনার প্রকল্পের জন্য ড্যাশবোর্ডগুলির একটি তালিকায় নিয়ে যাবে৷ Google Home Analytics - ক্লাউড ইন্টিগ্রেশন ড্যাশবোর্ড নির্বাচন করুন।

5edd3751323176dd.png

  1. হাইলাইট করা সময়সীমার জন্য ত্রুটি কোডগুলি দেখতে ক্লাউড পূর্ণতা ত্রুটি - স্ট্যাটাস ব্রেকডাউন চার্টে স্ক্রোল করুন৷

c468743c20a11c15.png

PARTNER_RESPONSE_MISSING_DEVICE ত্রুটি কোড মূল কারণটির জন্য একটি ইঙ্গিত প্রদান করে৷ এর পরে, আরও বিশদ বিবরণের জন্য ত্রুটি কোডের উপর ভিত্তি করে ইভেন্ট লগগুলি পুনরুদ্ধার করুন৷

ইভেন্ট লগ অ্যাক্সেস করুন

ত্রুটি সম্পর্কে আরও বিস্তারিত জানার জন্য, ক্লাউড লগিং এর মাধ্যমে আপনার স্মার্ট হোম অ্যাকশনগুলির জন্য ইভেন্ট লগগুলি অ্যাক্সেস করুন৷

Google ক্লাউড প্ল্যাটফর্মে নেভিগেশন মেনু খুলুন, এবং অপারেশনগুলির অধীনে, আপনার প্রকল্পের ইভেন্ট লগগুলি অ্যাক্সেস করতে লগিং > লগ এক্সপ্লোরার নির্বাচন করুন৷ বিকল্পভাবে, আপনি অনুসন্ধান বাক্সে লগ এক্সপ্লোরার অনুসন্ধান করতে পারেন।

ক্যোয়ারী বিভাগে, ক্যোয়ারী লিখুন PARTNER_RESPONSE_MISSING_DEVICE এবং রান ক্যোয়ারী ক্লিক করুন। ক্যোয়ারীটির সাথে মিলিত লগগুলি ক্যোয়ারী ফলাফল বিভাগে প্রদর্শিত হয়।

747cca0f1249a5a.png

ত্রুটির লগটি ত্রুটির বিবরণ সহ একটি স্মার্ট হোম ইভেন্ট দেখায়:

  • সাম্প্রতিক ব্যর্থ ভয়েস কমান্ডের সাথে সংশ্লিষ্ট ব্যবহারকারীর পদক্ষেপ হল "রিজুমিং ওয়াশার" ( actionType: " STARTSTOP_UNPAUSE "),
  • সংশ্লিষ্ট ডিবাগিং বার্তাটি হল " JSON response does not include device. "

ডিবাগিং বার্তার উপর ভিত্তি করে, আপনার পরীক্ষা করা উচিত কেন ওয়াশার অ্যাপটি EXECUTE প্রতিক্রিয়াতে সঠিক ডিভাইসটি অন্তর্ভুক্ত করে না।

ত্রুটির মূল কারণ চিহ্নিত করুন

functions/index.js এ, EXECUTE হ্যান্ডলার খুঁজুন ( onExecute অ্যারেতে) যা প্রতিটি কমান্ডের স্থিতি এবং নতুন ডিভাইসের অবস্থা প্রদান করে। একটি EXECUTE প্রতিক্রিয়াতে ডিভাইস আইডি সন্নিবেশ করা updateDevice ফাংশনের সমাধানের উপর নির্ভর করে:

index.js

app.onExecute(async (body) => {
 ...

 for (const command of intent.payload.commands) {
   for (const device of command.devices) {
     for (const execution of command.execution) {
       executePromises.push(
           updateDevice(execution, device.id)
               .then((data) => {
                 result.ids.push(device.id);
                 Object.assign(result.states, data);
               })
               .catch((e) =>
                 functions.logger.error('EXECUTE',
                     device.id, e.message)));
     }
   }
 }

updateDevice ফাংশনটি কীভাবে ওয়াশারে পজ/রিজুমে পরিচালনা করে তা আরও পরীক্ষা করে দেখুন, এবং আপনি পজ/রিজুমে কমান্ডের সাথে মিলের জন্য স্ট্রিংটি ভুল দেখতে পাবেন:

index.js

const updateDevice = async (execution, deviceId) => {
 const {params, command} = execution;
 let state; let ref;
 switch (command) {
   ...
   case 'action.devices.commands.PauseUnpausePause':
     state = {isPaused: params.pause};
     if (params.pause) state.isRunning = false;
     ref = firebaseRef.child(deviceId).child('StartStop');
     break;
 }

 return ref.update(state)
     .then(() => state);
};

ত্রুটি ঠিক করুন

এখন আপনি ত্রুটির মূল কারণ চিহ্নিত করেছেন, আপনি বিরতি / পুনরায় শুরু কমান্ডের জন্য স্ট্রিং সংশোধন করতে পারেন:

index.js

const updateDevice = async (execution, deviceId) => {
 const {params, command} = execution;
 let state; let ref;
 switch (command) {
   ...
   case 'action.devices.commands.PauseUnpause':
     state = {isPaused: params.pause};
     if (params.pause) state.isRunning = false;
     ref = firebaseRef.child(deviceId).child('StartStop');
     break;
 }

 return ref.update(state)
     .then(() => state);
};

আপনার ফিক্স পরীক্ষা

Firebase CLI ব্যবহার করে আপডেট করা কোড স্থাপন করুন:

firebase deploy --only functions

নিম্নলিখিত ভয়েস কমান্ডগুলি পুনরায় চেষ্টা করুন, এবং আপনি যখন ওয়াশারকে বিরতি / পুনরায় চালু করবেন তখন আপনি সহকারী সঠিকভাবে প্রতিক্রিয়া দেখতে পাবেন।

"ওহে গুগল, আমার ওয়াশার থামান।"

=>

"অবশ্যই, ওয়াশার থামাচ্ছি।"

"ওহে গুগল, আমার ওয়াশার আবার শুরু কর।"

=>

"বুঝলাম, ওয়াশার আবার চালু করছি।"

আপনি প্রশ্ন জিজ্ঞাসা করে আপনার ওয়াশারের বর্তমান অবস্থা পরীক্ষা করতে পারেন।

"ওহে গুগল, আমার ওয়াশার কি চালু আছে?"

"ওহে গুগল, আমার ওয়াশার কি চলছে?"

"ওহে গুগল, আমার ওয়াশার কোন সাইকেল চালু আছে?"

4. টেস্ট স্যুট দিয়ে আপনার অ্যাকশন পরীক্ষা করুন

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

স্মার্ট হোমের জন্য টেস্ট স্যুট চালান

টেস্ট স্যুট দ্বারা আপনার স্মার্ট হোম অ্যাকশন পরীক্ষা করতে এই নির্দেশাবলী অনুসরণ করুন:

  1. আপনার ওয়েব ব্রাউজারে, স্মার্ট হোমের জন্য টেস্ট স্যুট খুলুন।
  2. উপরের-ডান কোণায় বোতামটি ব্যবহার করে Google-এ সাইন ইন করুন। এটি টেস্ট স্যুটকে সরাসরি Google অ্যাসিস্ট্যান্টকে কমান্ড পাঠাতে দেয়।
  3. প্রজেক্ট আইডি ফিল্ডে, আপনার স্মার্ট হোম অ্যাকশনের প্রোজেক্ট আইডি লিখুন। এবং তারপর এগিয়ে যেতে পরবর্তী ক্লিক করুন.
  4. টেস্ট সেটিংস ধাপে, আপনি টেস্ট স্যুট দেখতে পাবেন ডিভাইসের ধরন এবং ওয়াশারের বৈশিষ্ট্যের তালিকা।

78ed6a1ebdb581bf.png

  1. টেস্ট রিকোয়েস্ট সিঙ্ক অপশনটি অক্ষম করুন যেহেতু নমুনা ওয়াশার অ্যাপে ওয়াশার যোগ / অপসারণ / পুনঃনামকরণ করার জন্য কোনও UI নেই৷ একটি প্রোডাকশন সিস্টেমে, ব্যবহারকারী যখনই ডিভাইসগুলি যোগ / অপসারণ / পুনঃনামকরণ করে তখন আপনাকে অবশ্যই অনুরোধ সিঙ্ক ট্রিগার করতে হবে৷
  2. পরীক্ষা চালানো শুরু করতে পরবর্তী ক্লিক করুন।

টেস্ট স্যুট চালানো শেষ হওয়ার পরে, পরীক্ষার ক্ষেত্রে ফলাফল দেখুন। আপনি নিজ নিজ ত্রুটি বার্তা সহ ধরা দুটি ব্যর্থ পরীক্ষার ক্ষেত্রে লক্ষ্য করবেন:

5838d10631c98ed2.png

ব্যর্থতার জন্য আপনার স্মার্ট হোম অ্যাকশন ডিবাগ করতে, আপনাকে প্রথমে ত্রুটি বার্তা বিশ্লেষণ করে ত্রুটির মূল কারণ সনাক্ত করতে হবে।

ত্রুটি বার্তা বিশ্লেষণ

বিকাশকারীদের মূল কারণ সনাক্ত করতে সহায়তা করার জন্য, টেস্ট স্যুট প্রতিটি ব্যর্থ পরীক্ষার ক্ষেত্রে ত্রুটির বার্তাগুলি দেখায় যা ব্যর্থতার কারণ নির্দেশ করে।

উপরের প্রথম ব্যর্থ পরীক্ষার ক্ষেত্রে,

99e4e5d06965a8a7.png

এর ত্রুটি বার্তাটি নির্দেশ করে যে টেস্ট স্যুট "isPause": true , কিন্তু প্রকৃত রাজ্যগুলিতে শুধুমাত্র "isPause": false

এছাড়াও, দ্বিতীয় ব্যর্থ পরীক্ষার ক্ষেত্রে ত্রুটির বার্তাটি আপনার স্মার্ট হোম অ্যাকশন থেকে QUERY প্রতিক্রিয়ার রাজ্যগুলিকে নির্দেশ করে যার মধ্যে রয়েছে "isPause": true , যা "isPause": false :

fdb5124102e3a37.png

উভয় ত্রুটি বার্তা অনুসারে, আপনার তারপরে আপনার অ্যাকশন রিপোর্টের অবস্থা সঠিক মান সহ isPaused কিনা তা পরীক্ষা করা উচিত।

ত্রুটির মূল কারণ চিহ্নিত করুন

ওপেন functions/index.js , যেটিতে reportstate ফাংশন রয়েছে যা রিপোর্ট স্টেটের মাধ্যমে হোম গ্রাফে স্টেট পরিবর্তন পোস্ট করে। রিপোর্ট স্টেট পেলোড পরিদর্শন করুন, এবং আপনি দেখতে পাবেন পেলোডটিতে isPaused স্টেট নেই, যা টেস্ট স্যুট ব্যর্থ পরীক্ষার ক্ষেত্রে পরীক্ষা করেছে।

index.js

exports.reportstate = functions.database.ref('{deviceId}').onWrite(
    async (change, context) => {
      ...

      const requestBody = {
        requestId: 'ff36a3cc', /* Any unique ID */
        agentUserId: USER_ID,
        payload: {
          devices: {
            states: {
              /* Report the current state of our washer */
             [context.params.deviceId]: {
                online: true,
                on: snapshot.OnOff.on,
                isRunning: snapshot.StartStop.isRunning,
                currentRunCycle: [{
                  currentCycle: 'rinse',
                  nextCycle: 'spin',
                  lang: 'en',
                }],
                currentTotalRemainingTime: 1212,
                currentCycleRemainingTime: 301,
              },
            },
          },
        },
      };

      const res = await homegraph.devices.reportStateAndNotification({
        requestBody,
      });
      ...
    });

ত্রুটি ঠিক করুন

এখন যেহেতু আপনি ত্রুটির মূল কারণ চিহ্নিত করেছেন, রিপোর্ট স্টেট পেলোডে isPaused অবস্থা যোগ করে functions/index.js সংশোধন করুন:

index.js

exports.reportstate = functions.database.ref('{deviceId}').onWrite(
    async (change, context) => {
      ...

      const requestBody = {
        requestId: 'ff36a3cc', /* Any unique ID */
        agentUserId: USER_ID,
        payload: {
          devices: {
            states: {
              /* Report the current state of our washer */
             [context.params.deviceId]: {
                online: true,
                on: snapshot.OnOff.on,
                isPaused: snapshot.StartStop.isPaused,
                isRunning: snapshot.StartStop.isRunning,
                currentRunCycle: [{
                  currentCycle: 'rinse',
                  nextCycle: 'spin',
                  lang: 'en',
                }],
                currentTotalRemainingTime: 1212,
                currentCycleRemainingTime: 301,
              },
            },
          },
        },
      };
      ...
    });

আপনার ফিক্স পরীক্ষা

Firebase CLI ব্যবহার করে আপডেট করা কোড স্থাপন করুন:

$ firebase deploy --only functions

স্মার্ট হোমের জন্য টেস্ট স্যুটটি পুনরায় চালান, এবং আপনি দেখতে পাবেন যে সমস্ত পরীক্ষায় উত্তীর্ণ হয়েছে৷

148837f85d377dd6.png

5. অভিনন্দন

17d485868a6771bc.png

অভিনন্দন! আপনি স্মার্ট হোম এবং GCP মেট্রিক্স এবং লগিং এর জন্য টেস্ট স্যুটের মাধ্যমে স্মার্ট হোম অ্যাকশন সংক্রান্ত সমস্যার সমাধান করতে শিখেছেন।

আরও জানুন

এই কোডল্যাবটি তৈরি করে, নিম্নলিখিত অনুশীলনগুলি চেষ্টা করুন এবং অতিরিক্ত সংস্থানগুলি অন্বেষণ করুন:

আপনি ব্যবহারকারীদের কাছে আপনার অ্যাকশন প্রকাশ করার সার্টিফিকেশন প্রক্রিয়া সহ পর্যালোচনার জন্য অ্যাকশন পরীক্ষা এবং জমা দেওয়ার বিষয়ে আরও জানতে পারেন।