১. ভূমিকা
একটি বিদ্যমান এজেন্টে নতুন ফিচার যোগ করা — যেমন একটি নতুন ডেটাবেস-সমর্থিত সক্ষমতা — এর জন্য সাধারণত বয়লারপ্লেট কোড লিখতে হয়, ইন্টিগ্রেশনগুলো সংযুক্ত করতে হয় এবং কোডবেসে আগে থেকেই থাকা প্যাটার্নগুলোর সাথে সবকিছু সামঞ্জস্যপূর্ণ রাখতে হয়। অ্যান্টিগ্র্যাভিটি এই প্রক্রিয়ার প্রতিটি ধাপকে ত্বরান্বিত করে: এটি প্রয়োজনীয় প্রেক্ষাপট তৈরি করার জন্য আপনার কোডবেস বিশ্লেষণ করে, আপনার পর্যালোচনার জন্য সুসংগঠিত স্পেসিফিকেশন ও বাস্তবায়ন পরিকল্পনা তৈরি করে এবং কোডের পরিবর্তনগুলো কার্যকর করে — এই সবকিছুই পরিচালিত হয় ডোমেইন জ্ঞানের মাধ্যমে, যা এটি আপনাকে পুনঃব্যবহারযোগ্য দক্ষতা হিসেবে অর্জন করতে সাহায্য করে, এবং একটি প্রজেক্ট সংবিধান দ্বারা যা অলঙ্ঘনীয় নীতিগুলো প্রয়োগ করে। এই কোডল্যাবটি স্পেক-কিটকে ব্যাপকভাবে রেফারেন্স হিসেবে ব্যবহার করে স্পেসিফিকেশন ডকুমেন্টেশনকে উন্নত করার জন্য একটি নতুন চক্র প্রবর্তনের মাধ্যমে অ্যান্টিগ্র্যাভিটি স্পেক-ড্রাইভেন ডেভেলপমেন্ট প্যারাডাইমকে আরও শক্তিশালী করার একটি উপায় তুলে ধরে।
আপনি যা তৈরি করবেন
একটি স্থানীয়ভাবে পরিচালিত রেস্তোরাঁ কনসিয়ার্জ অ্যাপ্লিকেশন, যেখানে একটি সম্পূর্ণ এসডিডি চক্রের মাধ্যমে রিজার্ভেশন বুকিং যুক্ত করা হয়েছে:
- রিজার্ভেশন বুকিং — অতিথিরা টেবিল বুক করেন এবং রিজার্ভেশন যাচাই করেন, যা নতুন এমসিপি টুলবক্স ডেটাবেস টুলস এবং একটি ক্লাউড এসকিউএল
reservationsটেবিল দ্বারা সমর্থিত। - (চ্যালেঞ্জ) – এজেন্টের জন্য আপনার নিজস্ব UI তৈরি করুন
- (চ্যালেঞ্জ) – অ্যান্টিগ্র্যাভিটি এজেন্টের সাহায্যে গুগল ক্লাউডে ডেপ্লয় করুন
স্টার্টার কোডটি একটি কার্যকরী ADK এজেন্ট প্রদান করে, যাতে মেনু সার্চ (MCP টুলবক্সের মাধ্যমে কীওয়ার্ড ও সিমান্টিক) এবং ডায়েটারি প্রেফারেন্স ট্র্যাকিং (টুলকনটেক্সটের মাধ্যমে) সুবিধা রয়েছে। আপনি অ্যাপ্লিকেশন কোড নিজে হাতে না লিখেই এটিকে সম্প্রসারণ করতে পারেন — অ্যান্টিগ্র্যাভিটি আপনার স্পেসিফিকেশন অনুযায়ী এর বাস্তবায়ন পরিচালনা করে।

আপনি যা শিখবেন
- কীভাবে প্রোজেক্ট কনটেক্সট বুটস্ট্র্যাপ করতে হয় যাতে অ্যান্টিগ্র্যাভিটি একটি বিদ্যমান কোডবেস বুঝতে পারে
- কীভাবে ডোমেইন জ্ঞান (যেমন, ADK কোডল্যাব প্যাটার্ন) পুনঃব্যবহারের জন্য প্যাকেজ করে অ্যান্টিগ্র্যাভিটি স্কিল তৈরি করা যায়
- কীভাবে একটি প্রকল্প সংবিধান নির্ধারণ করা যায়, যার ভিত্তিতে পরিকল্পনা ও বিশ্লেষণের সময় SDD ওয়ার্কফ্লোগুলো যাচাই করে।
- অ্যান্টিগ্র্যাভিটিতে পদ্ধতিগতভাবে ফিচার যোগ করার জন্য কীভাবে স্পেক-ড্রাইভেন ডেভেলপমেন্ট (এসডিডি) ওয়ার্কফ্লো ব্যবহার করবেন
- MCP টুলবক্সের মাধ্যমে নতুন ডাটাবেস-সমর্থিত টুল ব্যবহার করে কীভাবে একটি ADK এজেন্টকে সম্প্রসারিত করা যায়
পূর্বশর্ত
- আপনার স্থানীয় মেশিনে গুগল অ্যান্টিগ্র্যাভিটি এবং
gitইনস্টল করা আছে। - একটি সক্রিয় বিলিং অ্যাকাউন্ট সহ একটি গুগল ক্লাউড অ্যাকাউন্ট সক্ষম করা হয়েছে।
- ইউজ কেসের প্রেক্ষাপট বোঝার জন্য, পূর্বশর্ত হিসেবে চারটি ADK কোডল্যাব পূর্বে সম্পন্ন করা (বা সমতুল্য জ্ঞান) সহায়ক হবে।
- ADK দিয়ে AI এজেন্ট তৈরি করা: ভিত্তি
- ADK দিয়ে AI এজেন্ট তৈরি: টুলস দ্বারা ক্ষমতায়ন
- ADK এবং CloudSQL ব্যবহার করে স্থায়ী AI এজেন্ট তৈরি করা
- ক্লাউড রানে ADK এজেন্ট স্থাপন, পরিচালনা এবং পর্যবেক্ষণ করুন
- টুল হিসেবে ডাটাবেস: ADK, MCP টুলবক্স এবং ক্লাউড SQL সহ Agentic RAG
২. আপনার পরিবেশ প্রস্তুত করুন
এই ধাপে স্টার্টার রিপোজিটরি ক্লোন করা হয়, গুগল ক্লাউডের সাথে প্রমাণীকরণ সম্পন্ন হয়, একটি ক্লাউড এসকিউএল ডেটাবেস প্রস্তুত করা হয় এবং আপনার স্থানীয় অ্যান্টিগ্র্যাভিটি পরিবেশ প্রস্তুত করা হয়।
পূর্বশর্তগুলি ইনস্টল করুন
আপনার সিস্টেমে নিম্নলিখিত CLI এক্সিকিউটেবলটি আছে কিনা তা নিশ্চিত করুন:
আপনার মেশিনের অপারেটিং সিস্টেমের ওপর ভিত্তি করে ইনস্টলেশনের নির্দেশাবলী ভিন্ন হয়।
স্টার্টার রিপোজিটরি ক্লোন করুন
Antigravity-তে একটি টার্মিনাল (অথবা আপনার সিস্টেম টার্মিনাল) খুলুন। কম্প্যানিয়ন রিপোটি ক্লোন করুন এবং ডিরেক্টরিতে প্রবেশ করুন:
git clone https://github.com/alphinside/sdd-adk-antigravity-starter.git sdd-adk-agents-agy
cd sdd-adk-agents-agy
Antigravity-তে ক্লোন করা রিপোজিটরিটি খুলুন। File -> Open Folder -> ক্লোন করা ডিরেক্টরি sdd-adk-agents-agy নির্বাচন করুন।
আপস্ট্রিম রিমোটটি সরিয়ে ফেলুন। SDD ওয়ার্কফ্লো ফিচার স্পেসিফিকেশনের জন্য গিট ব্রাঞ্চ তৈরি করে — রিমোটটি সরিয়ে ফেললে ভুলবশত স্টার্টার রিপোজিটরিতে পুশ হওয়া প্রতিরোধ করা যায়:
git remote remove origin
গুগল ক্লাউডের মাধ্যমে প্রমাণীকরণ করুন
দুটি প্রমাণীকরণ কমান্ড চালান। উভয়ই OAuth-এর জন্য একটি ব্রাউজার খোলে:
gcloud auth login
gcloud auth application-default login
যেহেতু আপনি অ্যান্টিগ্র্যাভিটি স্থানীয়ভাবে ব্যবহার করছেন, তাই আপনাকে ম্যানুয়ালি প্রমাণীকরণ করতে হবে। auth login gcloud CLI-কে প্রমাণীকরণ করে। application-default login আপনার অ্যাপ্লিকেশন দ্বারা ব্যবহৃত গুগল ক্লাউড SDK-গুলোকে প্রমাণীকরণ করে — ADK-এর Vertex AI কল এবং ক্লাউড SQL পাইথন কানেক্টর উভয়ই অ্যাপ্লিকেশন ডিফল্ট ক্রেডেনশিয়াল-এর উপর নির্ভর করে।
আপনার গুগল ক্লাউড প্রজেক্ট সেট আপ করুন
প্রজেক্ট সেটআপ স্ক্রিপ্ট চালানোর আগে লোকেশন ভেরিয়েবলগুলো .env ফাইলে লিখে রাখুন:
echo "GOOGLE_CLOUD_LOCATION=global" > .env
echo "REGION=us-central1" >> .env
- Vertex AI / Gemini API কল করার জন্য
GOOGLE_CLOUD_LOCATION=globalব্যবহার করা হয়। - ক্লাউড এসকিউএল এবং অন্যান্য জিসিপি পরিকাঠামোর জন্য
REGION=us-central1ব্যবহৃত হয়।
প্রজেক্ট সেটআপ স্ক্রিপ্টটি ডাউনলোড করে চালান। এটি ট্রায়াল বিলিং সহ একটি গুগল ক্লাউড প্রজেক্ট তৈরি বা যাচাই করে এবং প্রজেক্ট আইডিটি .env ফাইলে সংরক্ষণ করে, তারপর এটিকে সোর্স করুন:
curl -sL https://raw.githubusercontent.com/alphinside/cloud-trial-project-setup/main/setup_verify_trial_project.sh -o setup_verify_trial_project.sh
bash setup_verify_trial_project.sh && source .env
এপিআই সক্রিয় করা
প্রয়োজনীয় API-গুলো সক্রিয় করুন:
gcloud services enable \
aiplatform.googleapis.com \
sqladmin.googleapis.com \
compute.googleapis.com \
cloudresourcemanager.googleapis.com
নির্ভরতা ইনস্টল করুন
আমরা পাইথন প্রজেক্ট ম্যানেজার হিসেবে uv ব্যবহার করব। uv হলো রাস্ট (Rust) ভাষায় লেখা একটি দ্রুতগতির পাইথন প্যাকেজ ও প্রজেক্ট ম্যানেজার ( ডকুমেন্টেশন )। এই কোডল্যাবটি গতি এবং সরলতার জন্য এটি ব্যবহার করে। পাইথন ডিপেন্ডেন্সিগুলো ইনস্টল করুন:
uv sync
এরপর আপনার প্রোজেক্ট কনফিগারেশন দিয়ে ADK এজেন্টের .env ফাইলটি আপডেট করুন:
cat > restaurant_concierge/.env <<EOF
GOOGLE_CLOUD_PROJECT=${GOOGLE_CLOUD_PROJECT}
GOOGLE_CLOUD_LOCATION=global
GOOGLE_GENAI_USE_VERTEXAI=True
EOF
ডাটাবেস পরিকাঠামো এবং ডেটা প্রস্তুত করুন
ডাটাবেস পাসওয়ার্ড সেট করুন এবং এটি .env ফাইলে যোগ করুন:
export DB_PASSWORD=codelabpassword
echo "DB_PASSWORD=${DB_PASSWORD}" >> .env
এরপর, প্রয়োজনীয় সমস্ত পরিকাঠামো প্রস্তুত করতে scripts/setup_database.sh স্ক্রিপ্টটি চালান। এটি নিম্নলিখিত কাজগুলো করবে:
- ক্লাউড এসকিউএল ইনস্ট্যান্স তৈরি করুন
- ইনস্ট্যান্সটি প্রস্তুত কিনা তা পরীক্ষা করুন।
- ভার্টেক্স এআই-কে অনুমতি দিন
- ডাটাবেস তৈরি করুন
- বীজ ডাটাবেস
- MCP টুলবক্স সার্ভিসটি ব্যাকগ্রাউন্ডে চালান।
chmod +x scripts/setup_database.sh
./scripts/setup_database.sh > database_setup.log 2>&1 &
এই কমান্ডটি ব্যাকগ্রাউন্ডে সেটআপটি চালাবে, আপনি পর্যায়ক্রমে database_setup.log ফাইলে এর আউটপুট দেখতে পারেন।
এখন, কাজ শুরু করার জন্য আমাদের প্রয়োজনীয় সমস্ত স্টার্টার ADK এজেন্ট রিপো তৈরি হয়ে যাওয়ার কথা। সবকিছু প্রস্তুত হওয়ার অপেক্ষায় থাকাকালীন, চলুন পরবর্তী অংশে অ্যান্টিগ্র্যাভিটি এবং স্পেক-ড্রাইভেন ডেভেলপমেন্ট নিয়ে আরও আলোচনা করা যাক।
৩. স্টার্টার কোডটি পর্যালোচনা করুন এবং স্পেক-ড্রাইভেন ডেভেলপমেন্ট বুঝুন।
এই ধাপে স্টার্টার কোডের কাঠামো ব্যাখ্যা করা হয়েছে, স্পেক-ড্রাইভেন ডেভেলপমেন্ট পদ্ধতির সাথে পরিচয় করিয়ে দেওয়া হয়েছে, ডেটাবেসে ডেটা যুক্ত করা হয়েছে এবং বেস এজেন্টটি সম্প্রসারণ শুরু করার আগে সেটি সঠিকভাবে কাজ করছে কিনা তা যাচাই করা হয়েছে।
প্রকল্পের কাঠামো
অ্যান্টিগ্র্যাভিটি এডিটরে ক্লোন করা রিপো প্রজেক্টটি খুলুন এবং ডিরেক্টরি বিন্যাসটি পর্যালোচনা করুন:
sdd-adk-agents-agy/ ├── .agents/ │ ├── workflows/ # SDD slash commands (/speckit.*) – manual trigger │ │ ├── speckit.specify.md │ │ ├── speckit.clarify.md │ │ ├── speckit.plan.md │ │ ├── speckit.tasks.md │ │ ├── speckit.analyze.md │ │ ├── speckit.implement.md │ │ ├── speckit.checklist.md │ │ └── speckit.constitution.md │ ├── skills/ # Antigravity skills (loaded on demand, agent determined) │ │ ├── mcp-toolbox-postgres/ │ │ │ └── SKILL.md # MCP Toolbox config skill │ │ └── repo-research/ │ │ └── SKILL.md # Repo analysis skill │ └── rules/ # Always-active context ├── .specify/ # spec-kit SDD templates and memory │ ├── memory/constitution.md │ ├── templates/ │ └── scripts/ ├── restaurant_concierge/ # ADK agent package │ ├── __init__.py │ ├── agent.py # LlmAgent + ToolContext tools + Toolbox integration │ └── .env # Vertex AI configuration ├── server.py # FastAPI server wrapping the agent ├── tools.yaml # MCP Toolbox tool definitions ├── scripts/ # Setup scripts └── pyproject.toml
মূল ফাইল
এজেন্ট অ্যাপ্লিকেশন ফাইল
-
restaurant_concierge/agent.py— মূল এজেন্ট। এটি একটিLlmAgentযা MCP টুলবক্স ডাটাবেস টুলগুলোকেToolContextভিত্তিক খাদ্যতালিকাগত পছন্দ ট্র্যাকিংয়ের সাথে একত্রিত করে। এজেন্টটি টুলবক্স সার্ভার থেকে সমস্ত টুল লোড করে এবং দুটি পাইথন ফাংশন (save_dietary_preference,get_dietary_preferences) যোগ করে, যেগুলো স্টেট ম্যানেজ করার জন্যToolContextব্যবহার করে। -
tools.yaml— এমসিপি টুলবক্স টুলের সংজ্ঞা। তিনটি মেনু সার্চ টুল সংজ্ঞায়িত করা হয়েছে: কীওয়ার্ড সার্চ (search_menu),pgvectorমাধ্যমে সিমান্টিক সার্চ (semantic_search_menu), এবং ক্যাটাগরি ফিল্টার (get_menu_by_category)। এখনও কোনো রিজার্ভেশন টুল নেই — সেগুলো আপনাকে পরে যোগ করতে হবে। -
server.py— একটি ন্যূনতম FastAPI সার্ভার, যা দেখায় কিভাবে আপনি ADK-কে একটি FastAPI অবজেক্ট হিসেবে অ্যাক্সেস করতে পারেন। ADK-এরget_fast_api_app()SSE স্ট্রিমিং এবং সেশন ম্যানেজমেন্ট API-এর জন্য/run_sseসহ বিভিন্ন বিল্ট-ইন এন্ডপয়েন্ট প্রদান করে।
অ্যান্টিগ্র্যাভিটি ফাইল
-
.agents/skills/mcp-toolbox-postgres/SKILL.md— একটি স্কিল যা MCP টুলবক্সের জন্য সঠিক tools.yaml কনফিগারেশন তৈরি করতে Antigravity-কে নির্দেশনা দেয়। এই স্কিলটি সঠিক RAG পাইপলাইন তৈরির জন্য প্রয়োজনীয়sources,tools, এবংembeddingModelsকনফিগারেশন শেখাবে। Antigravity দ্বারা স্বীকৃত হওয়ার জন্য আপনি সঠিক YAML ফ্রন্টম্যাটার যোগ না করা পর্যন্ত এই স্কিলটি সক্রিয় হবে না। -
.agents/skills/repo-research/SKILL.md— এটি এমন একটি স্কিল যা অ্যান্টিগ্র্যাভিটিকে শেখায় কীভাবে একটি রিপোজিটরিকে পর্যায়ক্রমে বিশ্লেষণ করতে হয় এবং একটি কাঠামোগত প্রজেক্ট কনটেক্সট ডকুমেন্ট তৈরি করতে হয়। এটি একটি ৪-ধাপের পদ্ধতি ব্যবহার করে: সারফেস স্ক্যান (শুধুমাত্র ডিরেক্টরি ট্রি), কনফিগ ও মেটাডেটা ফাইল, এন্ট্রি পয়েন্ট ও ডেটা মডেল, এবং তারপর নির্দিষ্ট গভীর বিশ্লেষণ — প্রতিটি ধাপ পরবর্তী ধাপে যাওয়ার আগে থেমে গিয়ে প্রাপ্ত ফলাফল লিখে রাখে। আপনি পরবর্তীতে YAML ফ্রন্টম্যাটার যোগ না করা পর্যন্ত এটি নিষ্ক্রিয় থাকে। একবার সক্রিয় হয়ে গেলে,.agents/rules/project-context.mdতৈরি করার জন্য এটিকে আহ্বান করুন — এটি একটি বিস্তারিত অনবোর্ডিং ডকুমেন্ট যা আর্কিটেকচার, রানটাইম ডিপেন্ডেন্সি, এপিআই সারফেস এবং ডোমেইন গ্লসারি অন্তর্ভুক্ত করে।
স্পেক-চালিত উন্নয়ন: অ্যান্টিগ্র্যাভিটির অন্তর্নির্মিত পরিকল্পনা থেকে কাঠামোগত এসডিডি পর্যন্ত
এআই কোডিং অ্যাসিস্ট্যান্টগুলো একটি প্রম্পট থেকে কোড তৈরি করা সহজ করে তোলে। এর ঝুঁকিটি হলো: আপনি একটি ফিচারের বর্ণনা এক বাক্যে দেন, অ্যাসিস্ট্যান্টটি শত শত লাইন লিখে ফেলে, এবং আপনি তা গ্রহণ করে নেন কারণ দেখতে ঠিকঠাক মনে হয়। একে কখনও কখনও 'ভাইব কোডিং' বলা হয় — আপনি অনুভূতির উপর নির্ভর করে কোড পরিচালনা করেন, আউটপুটটি কাজ করছে কি না তার উপর ভিত্তি করে তা গ্রহণ বা বর্জন করেন। প্রোটোটাইপ এবং ফেলে দেওয়ার মতো স্ক্রিপ্টের জন্য এটি দ্রুত কাজ করে। কিন্তু যখন কোডবেস বড় হতে থাকে, ফিচারগুলো একে অপরের সাথে মিথস্ক্রিয়া করে, অথবা যখন আপনি কয়েক সপ্তাহ পরে কোডটি পুনরায় দেখেন এবং কোনো একটি সিদ্ধান্ত কেন নেওয়া হয়েছিল তা মনে করতে পারেন না, তখন এই পদ্ধতিটি ভেঙে পড়ে।

স্পেক-ড্রাইভেন ডেভেলপমেন্ট (এসডিডি) এই প্রক্রিয়াটিতে একটি কাঠামো যোগ করে। কোনো কোড তৈরি করার আগে, আপনি একটি স্পেসিফিকেশন লেখেন: ফিচারটি কী কাজ করে, এটি কাদের জন্য, এবং এর সফলতার মানদণ্ড কী। এআই অ্যাসিস্ট্যান্ট সেই স্পেক অনুযায়ী কাজ করে — এবং এর আউটপুট পর্যালোচনা করার সময় আপনিও তাই করেন। স্পেকটিই উদ্দেশ্যের একমাত্র নির্ভরযোগ্য উৎস হয়ে ওঠে। যদি কোড স্পেক থেকে বিচ্যুত হয়, আপনি পর্যালোচনার সময় তা ধরে ফেলেন। যদি প্রয়োজনীয়তা পরিবর্তিত হয়, আপনি প্রথমে স্পেকটি আপডেট করেন, তারপর পুনরায় জেনারেট করেন। সিদ্ধান্তগুলো নথিভুক্ত করা হয়, তাৎক্ষণিকভাবে নেওয়া হয় না।
এর একটি বাস্তব অসুবিধা হলো: ভাইব কোডিংয়ের তুলনায় এসডিডি প্রতিটি ফিচারের জন্য ধীরগতির। কোড লেখার আগে আপনাকে ডকুমেন্ট তৈরি করতে হয়। কিন্তু এর সুফল বহুগুণে বেড়ে যায় — কোডবেসের প্রতিটি ভবিষ্যৎ পরিবর্তনের একটি প্রেক্ষাপট থাকে, এআই দ্বারা তৈরি প্রতিটি ইমপ্লিমেন্টেশনের একটি পর্যালোচনাযোগ্য চুক্তি থাকে, এবং আপনি স্মৃতি থেকে সিদ্ধান্ত ব্যাখ্যা করার পরিবর্তে স্পেসিফিকেশন দেখিয়ে সহযোগীদের (মানুষ বা এআই) কাজে যুক্ত করতে পারেন।
অ্যান্টিগ্র্যাভিটি ইতিমধ্যেই স্পেক-ড্রাইভেন ডেভেলপমেন্ট নীতি অনুসরণ করে। আপনি যখন এজেন্টটিকে প্ল্যানিং মোডে সেট করেন, তখন এটি কোনো কোড লেখার আগে দুটি আর্টিফ্যাক্ট তৈরি করে:
- বাস্তবায়ন পরিকল্পনা — প্রস্তাবিত প্রযুক্তিগত পদ্ধতি, ফাইলের পরিবর্তন এবং স্থাপত্য সংক্রান্ত সিদ্ধান্তের একটি সংক্ষিপ্ত বিবরণ

- করণীয় তালিকা — কাজের বিষয়গুলির একটি সুসংগঠিত বিভাজন

অ্যান্টিগ্র্যাভিটি এক্সিকিউশনের আগে আপনাকে এই আর্টিফ্যাক্টগুলো পর্যালোচনা ও অনুমোদন করতে বলে। এই পরিকল্পনা-ও-বাস্তবায়ন চক্রটিই স্পেক-ড্রাইভেন ডেভেলপমেন্টের মূল ভিত্তি: স্পেসিফিকেশন কোডকে পথ দেখায়, এর উল্টোটা নয়।
এই কোডল্যাবটি গিটহাবের একটি স্পেসিফিকেশন-চালিত ডেভেলপমেন্ট ফ্রেমওয়ার্ক ‘স্পেক-কিট’ -এর উপর ভিত্তি করে একটি সুনির্দিষ্ট ও ভার্সন-নিয়ন্ত্রিত ওয়ার্কফ্লোর মাধ্যমে সেই ভিত্তিকে আরও এগিয়ে নিয়ে যায়। প্রতিটি ফিচার একটি সুচিন্তিত পাইপলাইনের মধ্য দিয়ে যায়, যেখানে প্রতিটি আর্টিফ্যাক্ট একটি স্বতন্ত্র ডকুমেন্ট হিসেবে কাজ করে, যা আপনি git -এ পর্যালোচনা, সম্পাদনা এবং ট্র্যাক করতে পারেন। এই পাইপলাইনে দুটি ঐচ্ছিক কোয়ালিটি-গেট পর্যায় (স্পষ্ট করা এবং বিশ্লেষণ করা) অন্তর্ভুক্ত রয়েছে, যা কোনো সমস্যা বাস্তবায়নের পর্যায়ে পৌঁছানোর আগেই তা শনাক্ত করে।
পর্যায় | প্রত্নবস্তু | উদ্দেশ্য |
| | কী তৈরি করতে হবে তা নির্ধারণ করুন (ব্যবহারকারীর জন্য উপযোগী, প্রযুক্তি-নিরপেক্ষ) |
| আপডেট করা | অনির্দিষ্ট ক্ষেত্রগুলো চিহ্নিত করুন, সুনির্দিষ্ট ও স্পষ্টীকরণমূলক প্রশ্ন জিজ্ঞাসা করুন, এবং উত্তরগুলো স্পেসিফিকেশনে লিপিবদ্ধ করুন। |
| | কীভাবে এটি তৈরি করা যায় তার নকশা (প্রযুক্তিগত পদ্ধতি, ডেটা মডেল, গবেষণা) |
| | পরিকল্পনাটিকে সুশৃঙ্খল ও কার্যকর ধাপে ভাগ করুন। |
| বিশ্লেষণ প্রতিবেদন | বাস্তবায়নের আগে ঝুঁকি, ঘাটতি বা অনুপস্থিত বিশেষ পরিস্থিতি চিহ্নিত করার জন্য কাজগুলো পর্যালোচনা করুন। |
| কোড পরিবর্তন | কাজগুলো সম্পন্ন করুন এবং প্রতিটি সম্পন্ন হলে টিক চিহ্ন দিন। |

প্রতিটি আর্টিফ্যাক্ট specs/<feature-branch>/ ফোল্ডারে একটি ফাইল হিসেবে সংরক্ষিত থাকে, গিট-এ ভার্সন-কন্ট্রোল করা হয় এবং এটি পুনঃব্যবহারযোগ্য। যদি কোনো আলোচনা মাঝপথে থেমে যায় বা আপনি পরে কোনো সিদ্ধান্ত পুনর্বিবেচনা করতে চান, তাহলে স্পেসিফিকেশন ডকুমেন্টগুলো সবসময় সেখানেই থাকে — চ্যাট হিস্ট্রিতে চাপা পড়ে থাকে না।
স্টার্টার রিপোটিতে .agents/workflows/ ফোল্ডারে এই SDD ওয়ার্কফ্লো এবং .specify/templates/ টেমপ্লেটগুলো অন্তর্ভুক্ত রয়েছে। পরবর্তীতে এজেন্টে নতুন ফিচার যোগ করার জন্য আপনি এগুলো ব্যবহার করবেন।
৪. অ্যান্টিগ্র্যাভিটি দিয়ে বুটস্ট্র্যাপ প্রজেক্টের প্রেক্ষাপট
এখন, চলুন এমন একটি পরিস্থিতি দিয়ে বিষয়গুলো অনুকরণ করি যা আমাদের দৈনন্দিন কাজের "একটু কাছাকাছি":
- ভালোভাবে পরিচালিত নয় এমন সংগ্রহস্থল
- README অপ্রচলিত
- ডকুমেন্টেশন ঘন ঘন আপডেট করা হয় না
এই ধরনের পরিস্থিতিতে আমরা প্রথমেই যা করতে চাই তা হলো, যে প্রজেক্টটিতে আমরা অ্যান্টিগ্র্যাভিটিকে কাজ করাতে চাই, সেটির জন্য একটি ম্যাপ বা প্রেক্ষাপট তৈরি করা। এই ধাপে এমন একটি পদ্ধতির উদাহরণ দেখানো হয়েছে, যার মাধ্যমে রিপোজিটরি বিশ্লেষণ করে এবং একটি প্রজেক্ট কনটেক্সট ডকুমেন্ট তৈরি করার মতো একটি স্কিল তৈরির মাধ্যমে অ্যান্টিগ্র্যাভিটিকে একটি বিদ্যমান কোডবেস সম্পর্কে গভীর ধারণা দেওয়া যায়।
এটি প্রকল্পের গঠনতন্ত্রও তৈরি করে — অর্থাৎ সেই অলঙ্ঘনীয় নীতিগুলি, যেগুলোর ভিত্তিতে এসডিডি ওয়ার্কফ্লো যাচাই করা হয়। সব মিলিয়ে, এইগুলি অ্যান্টিগ্র্যাভিটিকে পরবর্তী এসডিডি চক্রগুলির জন্য প্রয়োজনীয় প্রেক্ষাপট এবং সীমাবদ্ধতা প্রদান করে।
অ্যান্টিগ্র্যাভিটি প্রসঙ্গ শ্রেণিবিন্যাস
অ্যান্টিগ্র্যাভিটি তিনটি প্রেক্ষাপট স্তর ব্যবহার করে, যার প্রতিটির পরিধি ভিন্ন:
- নিয়মাবলী (
.agents/rules/): সর্বদা-সক্রিয় নির্দেশাবলী। এই ওয়ার্কস্পেসের প্রতিটি কথোপকথনে এগুলো দেখা যায় (যদি আপনি এটি সক্রিয় করে থাকেন)। আর্কিটেকচার সংক্রান্ত সিদ্ধান্ত, কোডিং স্ট্যান্ডার্ড বা টেকনোলজি স্ট্যাকের তথ্যের মতো প্রোজেক্ট-ব্যাপী প্রেক্ষাপটের জন্য নিয়মাবলী ব্যবহার করুন। - দক্ষতা (
.agents/skills/): চাহিদা অনুযায়ী জ্ঞান। অ্যান্টিগ্র্যাভিটি শুধুমাত্র তখনই একটি দক্ষতা লোড করে যখন বর্তমান কাজটি দক্ষতারdescriptionক্ষেত্রের সাথে মিলে যায়। নির্দিষ্ট ক্ষেত্রের তথ্যসূত্র হিসেবে দক্ষতা ব্যবহার করুন। - ওয়ার্কফ্লো (
.agents/workflows/): সংরক্ষিত প্রম্পট যা/কমান্ড দিয়ে চালু করা হয়। SDD পাইপলাইনের মতো পুনরাবৃত্তিমূলক বহু-ধাপের প্রক্রিয়ার জন্য ওয়ার্কফ্লো ব্যবহার করুন।
দক্ষতাগুলো সক্রিয় করুন
স্টার্টার রিপোটিতে .agents/skills/ ফোল্ডারে আগে থেকে লেখা দুটি স্কিল রয়েছে। এগুলোতে বিস্তারিত নির্দেশাবলী আছে, কিন্তু প্রয়োজনীয় YAML ফ্রন্টম্যাটারের পরিবর্তে এগুলো TODO(codelab) কমেন্ট দিয়ে শুরু হয়। ফ্রন্টম্যাটার ছাড়া Antigravity এগুলো খুঁজে পায় না।
অ্যান্টিগ্র্যাভিটি স্কিলের জন্য ফাইলের শীর্ষে দুটি ফিল্ড সহ একটি YAML ফ্রন্টম্যাটার ব্লক প্রয়োজন:
-
name— দক্ষতার একটি অনন্য শনাক্তকারী -
description— একটি স্বাভাবিক ভাষার সারাংশ, যার সাথে অ্যান্টিগ্র্যাভিটি মিলিয়ে দেখে কোনো নির্দিষ্ট অনুরোধের জন্য কোন দক্ষতাটি লোড করতে হবে তা সিদ্ধান্ত নেয়।
এডিটরে .agents/skills/mcp-toolbox-postgres/SKILL.md ফাইলটি খুলুন । উপরের TODO(codelab) কমেন্ট লাইনগুলো এই ফ্রন্টম্যাটার দিয়ে প্রতিস্থাপন করুন:
---
name: mcp-toolbox-postgres
description: Configure MCP Toolbox for PostgreSQL — sources, tools, and embedding models
---
এডিটরে .agents/skills/repo-research/SKILL.md ফাইলটি খুলুন । উপরের TODO(codelab) কমেন্ট লাইনগুলো এই ফ্রন্টম্যাটার দিয়ে প্রতিস্থাপন করুন:
---
name: repo-research
description: Analyze a repository's structure, technologies, and patterns to create or update a project context document. Use when asked to research, analyze, or understand a codebase.
---
যাচাই করুন উভয় দক্ষতারই বৈধ ফ্রন্টম্যাটার আছে:
head -4 .agents/skills/mcp-toolbox-postgres/SKILL.md
head -4 .agents/skills/repo-research/SKILL.md
প্রতিটিতে name: এবং description: ফিল্ডের চারপাশে --- বিভাজক থাকতে হবে। যদি বিভাজক বা ফিল্ডগুলো না থাকে, তাহলে Antigravity স্কিলটি চিনতে পারবে না।
উভয় দক্ষতাই চাহিদা অনুযায়ী লোড হয় — অ্যান্টিগ্র্যাভিটি আপনার অনুরোধটিকে description ক্ষেত্রের সাথে মিলিয়ে দেখে এবং শুধুমাত্র প্রাসঙ্গিক হলেই সম্পূর্ণ নির্দেশাবলী নিয়ে আসে।
সর্বজনীনভাবে উপলব্ধ দক্ষতা ইনস্টল করুন
ADK চিটশিট স্কিলস
আমরা পূর্বে আমাদের নিজেদের তৈরি করা স্কিলগুলো ( repo-research এবং mcp-toolbox-postgres স্কিল) পরীক্ষা করেছি। তবে আরও অনেক স্কিল আছে যা আমাদের সফটওয়্যার ডেভেলপমেন্টে সহায়ক এবং আমাদের কোডিং এজেন্টে সহজেই ইনস্টল করা যায়। উদাহরণস্বরূপ, এই টিউটোরিয়ালে আমাদের ADK-এর সাথে কাজ করতে হবে, তাই ADK দিয়ে কীভাবে বিল্ড করতে হয় সে সম্পর্কে আমাদের সঠিক জ্ঞান থাকা প্রয়োজন। চলুন, নিচের কমান্ডটি ব্যবহার করে ADK ডকুমেন্টেশন স্কিলটি ইনস্টল করা যাক।
npx skills add google/adk-docs
তারপর এটি আপনাকে নীচে দেখানো ছবির মতো ইনস্টলেশনটি নিশ্চিত করতে বলবে।

নিচের ছবির মতো কোন স্কিলগুলো ইনস্টল করবেন তা বেছে নেওয়ার জন্য পরবর্তী প্রম্পটে যেতে y চাপুন। আপাতত শুধু adk-cheatsheet দিয়েই কাজ চালানো যাক ( বেছে নিতে স্পেস চাপুন, তারপর নিশ্চিত করতে এন্টার চাপুন)।

তারপর, ডিফল্ট ইনস্টলেশন চালু করতে এবং আপনার বর্তমান প্রজেক্টে স্কিলটি ইনস্টল করতে, অন্য অপশনে যেতে শুধু এন্টার চাপুন।
আপনি .agents/skills ডিরেক্টরিতে adk-cheatsheet নামের নতুন ADK স্কিলটি যুক্ত হতে দেখবেন।
গুহামানবের দক্ষতা
টোকেন ব্যবহার কমানোর জন্য কার্যকর স্কিলগুলোর মধ্যে এই কেভম্যান স্কিলটি অন্যতম। এই স্কিলটি এজেন্টের আউটপুট টোকেন কমিয়ে আনতে পারে, যা এই টিউটোরিয়ালের মতো সম্পূর্ণ স্পেক-ড্রাইভেন ডেভেলপমেন্ট ব্যবহার করার সময় একটি ভালো সমন্বয় তৈরি করে।
npx skills add JuliusBrussee/caveman
আগের মতোই, আপাতত এখানে caveman স্কিলটি বেছে নেওয়া যাক।

তারপর, ডিফল্ট ইনস্টলেশন চালু করতে এবং আপনার বর্তমান প্রজেক্টে স্কিলটি ইনস্টল করতে, অন্য অপশনে যেতে শুধু এন্টার চাপুন।
এখন, আমাদের ৪টি স্কিল ইতিমধ্যেই কনফিগার করা এবং এসডিডি যাত্রা শুরু করার জন্য প্রস্তুত থাকা উচিত।
.agents/skills/ ├── adk-cheatsheet ├── caveman ├── mcp-toolbox-postgres └── repo-research
প্রকল্পের প্রেক্ষাপট তৈরি করুন
নিয়মাবলী ডিরেক্টরিটির অস্তিত্ব নিশ্চিত করুন:
mkdir -p .agents/rules
Antigravity-র এজেন্ট ম্যানেজার/চ্যাট বক্সে (এডিটর মোডে ctrl + L চাপুন), একটি নতুন কথোপকথন শুরু করুন। টাইপ করুন:
Research this repository and create a project context document, and communicate efficiently
অ্যান্টিগ্র্যাভিটি আপনার অনুরোধটিকে repo-research এবং caveman স্কিলের (দক্ষভাবে যোগাযোগের জন্য ব্যবহৃত কমান্ড) সাথে মিলিয়ে নেয় এবং পদ্ধতিগতভাবে কোডবেস বিশ্লেষণ করা শুরু করে। এটি কনফিগারেশন ফাইল, সোর্স কোড এবং ডকুমেন্টেশন পড়ে, তারপর এর প্রাপ্ত তথ্য দিয়ে প্রোজেক্ট কনটেক্সট টেমপ্লেটটি পূরণ করে।
কাজ শেষ হলে, এডিটরে .agents/rules/project-context.md ফাইলটি খুলুন। এতে প্রজেক্ট সম্পর্কিত সুনির্দিষ্ট তথ্য রয়েছে: টেকনোলজি স্ট্যাক (পাইথন ৩.১২, এডিকে, এমসিপি টুলবক্স, ক্লাউড এসকিউএল), প্রজেক্টের কাঠামো, ডেটা মডেল ( pgvector সহ মেনু_আইটেমস টেবিল), এবং এক্সটার্নাল ইন্টিগ্রেশন।

প্রকল্পের সংবিধান নির্ধারণ করুন
পরিকল্পনা এবং বিশ্লেষণের সময় SDD ওয়ার্কফ্লো .specify/memory/constitution.md এ থাকা একটি প্রজেক্ট সংবিধানকে রেফারেন্স হিসেবে ব্যবহার করে। /speckit.plan ওয়ার্কফ্লো এর উপর একটি "সংবিধান যাচাই" (Constitution Check) চালায়, এবং /speckit.analyze লঙ্ঘনগুলোকে CRITICAL হিসেবে চিহ্নিত করে। যদি সংবিধানটিকে প্লেসহোল্ডার টোকেনসহ একটি ফাঁকা টেমপ্লেট হিসেবে রাখা হয়, তবে এই যাচাইগুলোর জন্য কোনো কিছু থাকে না — ফলে পরিকল্পনা এবং বিশ্লেষণগুলো কোনো সুরক্ষাব্যবস্থা ছাড়াই চলে।
সংবিধানে প্রকল্পের অলঙ্ঘনীয় নীতিমালা নির্ধারণ করা হয়েছে। এটি একজন মাত্র ডেভেলপার দ্বারা পরিচালিত একটি ছোট রিপো, তাই সংবিধানেও সেই পরিধির প্রতিফলন থাকা উচিত — সবকিছু সহজ ও সামঞ্জস্যপূর্ণ রাখুন এবং অতিরিক্ত জটিলতা পরিহার করুন।
অ্যান্টিগ্র্যাভিটির এজেন্ট ম্যানেজারে, একটি নতুন কথোপকথন শুরু করুন। সংবিধান ওয়ার্কফ্লোটি চালান:
/speckit.constitution This is a small restaurant concierge ADK agent maintained by one developer. Set 3 principles: (1) All database operations go through MCP Toolbox tool definitions in tools.yaml — no raw SQL in Python code, no ORM. (2) Session state uses ADK ToolContext — no custom state management, no external state stores. (3) Keep it simple — follow existing file and naming conventions exactly.
অ্যান্টিগ্র্যাভিটি সংবিধান টেমপ্লেটটিকে সুনির্দিষ্ট নীতিমালা দিয়ে পূরণ করে, একটি সংস্করণ (১.০.০) নির্ধারণ করে এবং এসডিডি টেমপ্লেটগুলোর মধ্যে সামঞ্জস্যতা যাচাই করে।
.specify/memory/constitution.md এ তৈরি হওয়া সংবিধানটি পর্যালোচনা করুন। যাচাই করুন যে তিনটি মূলনীতি উপস্থিত আছে এবং স্পষ্টভাবে উল্লেখ করা হয়েছে।

৫. এসডিডি চক্র — রিজার্ভেশন বৈশিষ্ট্য যোগ করুন
এই ধাপে রেস্তোরাঁর কনসিয়ার্জ এজেন্টে রিজার্ভেশন বুকিং যোগ করার জন্য একটি সম্পূর্ণ SDD চক্র দেখানো হয়েছে। আপনি প্রতিটি ধাপ—নির্দিষ্টকরণ, স্পষ্টীকরণ, পরিকল্পনা, টাস্ক, বিশ্লেষণ, বাস্তবায়ন—এর মধ্য দিয়ে Antigravity-কে চালনা করবেন এবং পর্যবেক্ষণ করবেন কীভাবে প্রতিটি আর্টিফ্যাক্ট পূর্ববর্তীটির উপর ভিত্তি করে গড়ে ওঠে। এটাই এই কোডল্যাবের মূল শিক্ষণ অভিজ্ঞতা।
বৈশিষ্ট্যটি নির্দিষ্ট করুন
Antigravity-র এজেন্ট ম্যানেজারে, একটি নতুন আলোচনা শুরু করুন। একটি ফিচার বিবরণ সহ /speckit.specify ওয়ার্কফ্লো কমান্ডটি টাইপ করুন:
/speckit.specify Add reservation booking capability to the restaurant concierge agent. Guests should be able to make a table reservation by providing their name, party size, date, and time. They should also be able to check existing reservations. The agent should confirm reservation details before booking and handle special requests (e.g., "window seat", "birthday celebration").
অ্যান্টিগ্র্যাভিটি একটি ফিচার ব্রাঞ্চ তৈরি করে, একটি স্পেসিফিকেশন ডকুমেন্ট জেনারেট করে এবং কোয়ালিটি ভ্যালিডেশন চালায়। যদি অ্যান্টিগ্র্যাভিটি কোনো স্পষ্টীকরণমূলক প্রশ্ন উপস্থাপন করে, তবে উপরের ফিচার বিবরণের উপর ভিত্তি করে সেগুলোর উত্তর দিন।
স্পেসিফিকেশনটি ‘কী’ এবং ‘কেন’-এর উপর আলোকপাত করে — ‘কীভাবে’-এর উপর নয়। এটি SQL টেবিল, tools.yaml বা ADK API-এর উল্লেখ না করেই ব্যবহারকারীর অভিজ্ঞতা বর্ণনা করে ("অতিথিরা তাদের নাম, দলের সদস্য সংখ্যা, তারিখ এবং সময় প্রদান করে একটি রিজার্ভেশন বুক করতে পারবেন")। বাস্তবায়নের বিস্তারিত বিবরণ পরিকল্পনা পর্যায়ে আসে।
specs/<branch-name>/spec.md এ তৈরি হওয়া স্পেসিফিকেশনটি পর্যালোচনা করুন। এটিতে ফাংশনাল রিকোয়ারমেন্ট এবং সাকসেস ক্রাইটেরিয়া অন্তর্ভুক্ত আছে কিনা তা যাচাই করুন।

স্পেসিফিকেশনটি স্পষ্ট করুন (ঐচ্ছিক)
স্পেসিফিকেশনে অনির্দিষ্ট ক্ষেত্রগুলো শনাক্ত ও সমাধান করতে ক্লারিফাই ওয়ার্কফ্লোটি চালান:
/speckit.clarify
অ্যান্টিগ্র্যাভিটি স্পেসিফিকেশনটি স্ক্যান করে কোনো অস্পষ্টতা, অনুপস্থিত অ্যাকসেপ্টেন্স ক্রাইটেরিয়া এবং অসম্পূর্ণ রিকোয়ারমেন্টস খুঁজে বের করে। এটি সুনির্দিষ্ট কিছু স্পষ্টীকরণমূলক প্রশ্ন জিজ্ঞাসা করে—যার প্রত্যেকটির উত্তর একটি সংক্ষিপ্ত শব্দ বা বাক্যাংশের মাধ্যমে দেওয়া যায়। আপনার উত্তরগুলো সরাসরি স্পেসিফিকেশনে এনকোড করা হয়, যা প্ল্যানিং শুরু হওয়ার আগেই এটিকে আরও নির্ভুল করে তোলে।
বাস্তবায়নের পরিকল্পনা করুন
পরিকল্পনা কর্মপ্রবাহটি চালান:
/speckit.plan Update the restaurant concierge agent to multi agent architecture which separate responsibilities for handling menu and reservations. Use your ADK and MCP toolbox skill to implement it properly
অ্যান্টিগ্র্যাভিটি দুটি পর্যায়ের মাধ্যমে একটি প্রযুক্তিগত পরিকল্পনা তৈরি করে:
- গবেষণা পর্যায় — বিদ্যমান কোডবেস সম্পর্কিত অজানা বিষয়গুলোর সমাধান করে এবং
research.mdফাইল তৈরি করে। - ডিজাইন পর্যায় —
data-model.md(রিজার্ভেশন এনটিটি ডেফিনিশন) তৈরি করে এবংproject-context.mdআপডেট করে।
পরিকল্পনা করার সময় অ্যান্টিগ্র্যাভিটির adk-agent-development স্কিলটি ব্যবহার করা উচিত। মূল আর্টিফ্যাক্টগুলো পর্যালোচনা করুন:
-
specs/<branch-name>/plan.md— প্রযুক্তিগত পদ্ধতি: কোন ফাইলগুলো পরিবর্তন করতে হবে, কোন প্যাটার্ন অনুসরণ করতে হবে -
specs/<branch-name>/data-model.md— রিজার্ভেশন এনটিটির সংজ্ঞা (কলাম, টাইপ, সম্পর্ক) -
specs/<branch-name>/research.md— গৃহীত সিদ্ধান্ত এবং তার যুক্তি

কাজ তৈরি করুন
টাস্ক ওয়ার্কফ্লো চালান
/speckit.tasks
অ্যান্টিগ্র্যাভিটি প্ল্যানটিকে specs/<branch-name>/tasks.md এ একটি ক্রমবিন্যস্ত টাস্ক লিস্টে ভাগ করে। টাস্কগুলো একটি কঠোর চেকলিস্ট ফরম্যাট অনুসরণ করে, যেখানে আইডি, প্রায়োরিটি মার্কার এবং ফাইল পাথ থাকে, যেমন:
- [ ] [T001] [P] Create reservations table schema in scripts/seed_db.py - [ ] [T002] [P] Add create_reservation tool to tools.yaml - [ ] [T003] [P] Add list_reservations tool to tools.yaml - [ ] [T004] [P] Update agent instruction in restaurant_concierge/agent.py
কাজগুলোকে কয়েকটি পর্যায়ে ভাগ করা হয়েছে: সেটআপ → ভিত্তি স্থাপন → ইউজার স্টোরি → পরিমার্জন। কী তৈরি এবং পরিবর্তন করা হবে তা বোঝার জন্য কাজের তালিকাটি দেখুন।

কাজগুলো বিশ্লেষণ করুন (ঐচ্ছিক)
ঝুঁকি এবং ঘাটতি পর্যালোচনার জন্য টাস্কগুলো বিশ্লেষণ করতে অ্যানালাইজ ওয়ার্কফ্লোটি চালান:
/speckit.analyze
অ্যান্টিগ্র্যাভিটি স্পেক এবং প্ল্যানের সাথে টাস্ক লিস্ট মিলিয়ে দেখে, এবং অনুপস্থিত এজ কেস, সম্ভাব্য সাংঘর্ষিক টাস্ক, অথবা স্পেকের রিকোয়ারমেন্ট ও পরিকল্পিত কাজের মধ্যেকার ফাঁক খুঁজে বের করে। বাস্তবায়নের আগে গুরুতর সমস্যাগুলো সমাধান করুন।
৬. বাস্তবায়ন করুন
বাস্তবায়ন কর্মপ্রবাহটি চালান:
/speckit.implement
অ্যান্টিগ্র্যাভিটি একটি চূড়ান্ত বাস্তবায়ন পরিকল্পনা এবং টাস্ক আর্টিফ্যাক্ট উপস্থাপন করছে। কার্যক্রম এগিয়ে নিয়ে যাওয়ার জন্য এটি পর্যালোচনা ও অনুমোদন করুন।


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

কোডের পরিবর্তনগুলো পরীক্ষা করুন
বাস্তবায়ন সম্পন্ন হলে, মূল পরিবর্তনগুলো করা হয়েছে কিনা তা যাচাই করুন। ফাইলের নাম এবং বিষয়বস্তু ভিন্ন হতে পারে, কিন্তু tools.yaml এবং agent.py এর মতো এই প্যাটার্নগুলো অবশ্যই থাকতে হবে:
# Verify reservation tools were added to tools.yaml
grep -i "reservation" tools.yaml
আপনি এই ধরনের কিছু আউটপুট দেখতে পাবেন।
...
get_reservations_by_name:
Retrieve all reservations for a guest by their name. Uses case-insensitive
SELECT id, guest_name, party_size, reservation_datetime, special_requests, created_at
FROM reservations
ORDER BY reservation_datetime DESC
...
এবং agent.py এর জন্য
# Verify agent instruction was updated
grep -i "reservation" restaurant_concierge/agent.py
# Check what files changed
git diff --name-only
হয়তো আপনি এই ধরনের পরিবর্তন দেখতে পাবেন
...
- **Table Reservations**: Help guests book a table or check their existing reservations.
## Reservation Booking Rules
When a guest wants to make a reservation, collect ALL of the following before confirming:
**IMPORTANT**: Before calling `book_reservation`, you MUST:
- Only call `book_reservation` after the guest says "yes" or "confirm"
## Checking Reservations
When a guest asks to check their reservations:
- Use `get_reservations_by_name` to find their bookings
book_reservation,
...
এই পরিবর্তনগুলো সিড ডাটাবেস স্ক্রিপ্টকে প্রভাবিত করবে। আপডেট করা স্ক্রিপ্টটি reservations টেবিলটি তৈরি করবে, যদি সেটি আগে থেকে বিদ্যমান না থাকে। নতুন টেবিলটি তৈরি হয়েছে তা নিশ্চিত করে আপনি একটি আউটপুট দেখতে পাবেন (বিদ্যমান menu_items ডেটা সংরক্ষিত থাকবে)।
এই পর্যন্ত সবকিছু ঠিকঠাক চললে, আমরা ADK এজেন্ট ডেভ UI-তে ফিচারটি পরীক্ষা করতে পারি। নতুন টেবিলটি অন্তর্ভুক্ত করার জন্য চলুন ডাটাবেস মাইগ্রেশন করি এবং tools.yaml এ থাকা নতুন টুল ডেফিনিশনগুলো কার্যকর করার জন্য টুলবক্সটি রিস্টার্ট করি। চালু থাকা যেকোনো টুলবক্স প্রসেস বন্ধ করুন, তারপর একটি নতুন প্রসেস চালু করুন:
lsof -ti:5000 | xargs kill -9 2>/dev/null; echo "Done"
./scripts/setup_database.sh > database_setup.log 2>&1 &
Antigravity সঠিক কোড এবং কনফিগারেশন তৈরি করছে কিনা, তা জানতে আপনি database_setup.log এ আউটপুট লগটি পরীক্ষা করতে পারেন। যদি কোনো ত্রুটি দেখা দেয়, তবে তা সমাধান করার জন্য এজেন্টের সাথে ইন্টারঅ্যাক্ট করার চেষ্টা করুন।
সবকিছু ঠিকঠাক থাকলে, আমরা ADK ডেভ UI শুরু করতে পারি:
uv run adk web .
আপনার ব্রাউজারে http://localhost:8000 খুলুন এবং এই প্রম্পটগুলো দিয়ে পরীক্ষা করুন:
I'd like to book a table for 4 people on Friday at 7pm under the name Timmy
Do I have any upcoming reservations?


এখন, দুইবার Ctrl+C চেপে ADK ডেভ UI বন্ধ করুন।
৭. চ্যালেঞ্জসমূহ (ঐচ্ছিক)
আপনি এখন সম্পূর্ণ SDD কার্যপ্রবাহ সম্পর্কে জানেন। এটি পরীক্ষা করে দেখুন:
- রেস্তোরাঁর কনসিয়ার্জের জন্য একটি ওয়েব চ্যাট ইন্টারফেস তৈরি করতে দ্বিতীয়বার SDD সাইকেলটি চালান — এবার ধাপে ধাপে নির্দেশনা ছাড়াই।
- প্রোডাকশন সিনারিওর জন্য আপনার এজেন্টকে ক্লাউড রান-এ ডেপ্লয় করুন।
ইঙ্গিত
- প্রকল্পটির কোনো ফ্রন্টএন্ড ফ্রেমওয়ার্ক নেই। অ্যান্টিগ্র্যাভিটির উচিত সাধারণ HTML/CSS/JS প্রস্তাব করা — যদি এটি React বা অনুরূপ কিছুর পরামর্শ দেয়, তবে এটিকে সরলতার দিকে উৎসাহিত করুন (আপনার সংবিধানের 'সহজ রাখুন' নীতিটি এটি ধরতে পারবে)।
- ADK সার্ভার স্ট্রিমিংয়ের জন্য
/run_sseএবং সেশন ব্যবস্থাপনার জন্য/apps/{app_name}/users/{user_id}/sessionsউন্মুক্ত করে। অ্যান্টিগ্র্যাভিটি প্রজেক্ট কনটেক্সট থেকে এগুলো খুঁজে নেয়। - বাস্তবায়নের পরে,
uv run uvicorn server:app --host 0.0.0.0 --port 8080(adk webনয়) দিয়ে সার্ভারটি চালু করুন, যাতে স্ট্যাটিক ফাইল মাউন্ট কাজ করে। -
http://localhost:8080/static/index.html-এ পরীক্ষা করুন। - রেফারেন্স কোডল্যাবগুলোতে ইতিমধ্যেই দেখানো হয়েছে কিভাবে ADK এজেন্ট ডেপ্লয় এবং পারসিস্ট করতে হয়, Antigravity-কে এর রেফারেন্স দিন!
৮. অভিনন্দন!
আপনি হাতে অ্যাপ্লিকেশন কোড না লিখে, সম্পূর্ণভাবে অ্যান্টিগ্র্যাভিটির এসডিডি ওয়ার্কফ্লোর মাধ্যমে একটি রেস্তোরাঁ কনসিয়ার্জ এডিকে এজেন্টকে রিজার্ভেশন বুকিং সহ সম্প্রসারিত করেছেন।
আপনি যা তৈরি করেছেন
- একটি রেস্তোরাঁ কনসিয়ার্জ ADK এজেন্ট, যার মাধ্যমে মেনু সার্চ, সিমান্টিক সার্চ, খাদ্যাভ্যাসের পছন্দ ট্র্যাক করা এবং রিজার্ভেশন বুকিং করা যায়।
- রিপো গবেষণার জন্য একটি অ্যান্টিগ্র্যাভিটি স্কিল যা একটি প্রজেক্ট কনটেক্সট ডকুমেন্ট তৈরি ও রক্ষণাবেক্ষণ করে।
- একটি প্রকল্প সংবিধান যা পরিকল্পনা ও বিশ্লেষণের সময় অলঙ্ঘনীয় নীতিসমূহ বলবৎ করে।
- একটি সম্পূর্ণ SDD চক্র যা নির্দিষ্ট করা → স্পষ্ট করা → পরিকল্পনা করা → কাজসমূহ → বিশ্লেষণ করা → বাস্তবায়ন কর্মপ্রবাহ প্রদর্শন করে।
আপনি যা শিখেছেন
- বিদ্যমান কোডবেসে পদ্ধতিগতভাবে ফিচার যোগ করতে Antigravity-তে Spec-Driven Development ওয়ার্কফ্লো কীভাবে ব্যবহার করবেন
- কীভাবে অ্যান্টিগ্র্যাভিটি স্কিল তৈরি করা যায় যা বিভিন্ন কথোপকথনে পুনঃব্যবহারের জন্য ডোমেইন জ্ঞানকে প্যাকেজ করে।
- কীভাবে প্রোজেক্টের প্রেক্ষাপট বুটস্ট্র্যাপ করা যায়, যাতে অ্যান্টিগ্র্যাভিটি আর্কিটেকচার, প্যাটার্ন এবং প্রযুক্তিগত পছন্দ সম্পর্কে সুচিন্তিত সিদ্ধান্ত নিতে পারে।
- কীভাবে এমন একটি প্রকল্প সংবিধান সেট করবেন যার ভিত্তিতে SDD ওয়ার্কফ্লোগুলো যাচাই করা যায়
- MCP টুলবক্সের মাধ্যমে নতুন ডাটাবেস-সমর্থিত টুল ব্যবহার করে কীভাবে একটি ADK এজেন্টকে সম্প্রসারিত করা যায়
পরিষ্কার করা
চলমান যেকোনো স্থানীয় প্রসেস বন্ধ করুন (টুলবক্স):
pkill -f toolbox 2>/dev/null
চলমান চার্জ এড়াতে ক্লাউড এসকিউএল ইনস্ট্যান্সটি ডিলিট করুন:
gcloud sql instances delete restaurant-db --quiet
ঐচ্ছিকভাবে, সম্পূর্ণ প্রজেক্টটি মুছে ফেলুন:
gcloud projects delete $GOOGLE_CLOUD_PROJECT