- Platform: Coursera
- Instructor: John Rofrano
- Rating: 4.8/5 (222 ratings)
- Release Date: March 2025
- Course Link: https://www.coursera.org/learn/test-and-behavior-driven-development-tdd-bdd
این سند، نکات کلیدی دوره رو خلاصه میکنه. اگه فرصت داری، حتماً کل دوره رو تماشا کن—ارزشش رو داره.
- من نکات کلیدی دورههای مفید رو خلاصه میکنم تا بتونی سریع یاد بگیری و مرور کنی.
- فقط روی لینکهای
Ask AIکلیک کن تا عمیقتر وارد هر موضوعی بشی.
Teach Me: 5 Years Old | Beginner | Intermediate | Advanced | (reset auto redirect)
Learn Differently: Analogy | Storytelling | Cheatsheet | Mindmap | Flashcards | Practical Projects | Code Examples | Common Mistakes
Check Understanding: Generate Quiz | Interview Me | Refactor Challenge | Assessment Rubric | Next Steps
سلام! اگه داری وارد دنیای software testing میشی، این دوره واقعاً تحولآفرینه. John Rofrano، یه DevOps champ از IBM، توضیح میده که چرا testing فقط یه چکلیست نیست—بلکه راز ساخت کدهای محکم و مقاوم در برابر شکستهاست. با هم از پایهها شروع میکنیم، دستبهکار با TDD و BDD میشیم و حتی یه پروژه واقعی رو حل میکنیم. این خلاصه مثل یه cheat sheet عمل میکنه برای کدنویسی با اعتمادبهنفس، بدون اون دیباگینگهای بیپایان.
تست کردن جذاب نیست، اما ستون فقرات نرمافزارهای قابل اعتماد هست. این بخش با دید کلی شروع میشه: از جواهرات تاریخی مثل مأموریتهای Apollo تا pipelineهای مدرن DevOps. میبینی که چرا رد کردن testها مثل رانندگی بدون ترمز هست—شاید امروز کار کنه، اما فردا؟ فاجعه. John داستانهای شکستهای حماسی (سلام، Equifax breach) رو به اشتراک میذاره و تأکید میکنه که automated testing چطور همه چیز رو در CI/CD روان نگه میداره. نکته کلیدی: زود test کن، اغلب test کن، و هم روی happy paths (همه چیز عالی پیش میره) و هم sad paths (هرجومرج حاکمه) تمرکز کن.
-
مثال: مأموریت Apollo 11 و فرود روی ماه رو یادته؟ یه glitch سختافزاری نامحسوس به علاوه یه دستور اضافی از Buzz Aldrin، alarm restart سیستم رو فعال کرد. بدون telemetry real-time (دادههای "testing" اولیه)، mission control نمیتونست مسیر رو تأیید کنه. امروز، این مثل streaming logs برای گرفتن باگهای مخفی قبل از اینکه اپت رو نابود کنن، هست.
-
Link for More Details: Ask AI: Foundations of Testing
تیدیدی معادله رو برعکس میکنه: اول کد رویاییت رو تصور کن، یه test failing براش بنویس، بعد فقط به اندازهای کد بزن که pass بشه—و با refactoring تکرار کن. همهش در مورد تمرکز لیزری روی کاریه که کد باید بکنه، نه فقط هک کردن تا "کار کنه". John چرخه red-green-refactor رو demo میکنه و ابزارهای Python مثل PyUnit و Nose رو نشون میده که چطور کیفیت کد رو بالا میبرن و زندگی dev رو سرعت میدن. نکته حرفهای: تا ۹۰٪ defectها رو کم میکنه، طبق مطالعات IBM—آیندهت ازت تشکر میکنه.
-
مثال: تصور کن داری یه calculator ساده برای مساحت triangle کد میزنی. بدون TDD، ممکنه یه one-liner بفرستی که با stringها یا negativeها crash کنه و آروم جوابهای غلط بده. با TDD، اول testت spectacular fail میشه (red)، input checkها رو اضافه میکنی (green)، بعد polish میکنی (refactor). بوم—دیگه باگهای silent در production نداری.
-
Link for More Details: Ask AI: Test-Driven Development (TDD)
اما BDD TDD رو یه پله بالاتر میبره و از بیرون به رفتار سیستم نگاه میکنه—مثل اینکه shopping cart برای کاربر چطور حس میشه، نه فقط اینکه API ping میکنه یا نه. با Gherkin syntax (Given-When-Then)، سناریوهای plain-English میسازی که stakeholderها و devها همهش رو میفهمن. John روی Behave برای Python تمرکز میکنه، feature files، step implementations و Selenium برای UI automation رو پوشش میده. عالیه برای integration tests، مطمئن میشی که چیز درست رو میسازی، نه چیزی که فقط compile میشه.
-
مثال: برای یه سایت pet shop، یه سناریو BDD میتونه باشه: "Given pets in stock | When a customer searches for 'dog' | Then they see Fido but not Kitty the cat." Behave این رو روی UIت اجرا میکنه و منتظر "success" message میمونه تا تأیید کنه search لود شده—عالی برای گرفتن gremlinهای latency.
-
Link for More Details: Ask AI: Behavior-Driven Development (BDD)
با capstone تمومش کن: یه RESTful API برای backend e-commerce بساز با TDD برای CRUD ops، بعد BDD scenarios برای validate کردن admin UI. با coverage tools خطوط کد untested رو شکار میکنی، external services رو mock میکنی و fake data رو با factories لود میکنی. industry-real هست: از صفر تا microservice deployable، اثبات TDD/BDD در عمل. labsهای John با Nose برای running tests و Behave برای end-to-end checks راهنماییت میکنن—انتظار داشته باش تا آخرش مثل پرو حس کنی.
-
مثال: با TDD شروع کن برای "list products" endpoint—یه test بنویس که JSON list انتظار داره، bare-bones code رو implement کن تا pass بشه، بعد برای filters refactor کن. به BDD سوئیچ کن: "Given products exist | When an admin views the UI | Then they see editable fields." یه database failure رو mock کن تا error handling رو test کنی، مطمئن شی UI gracefully degrade میکنه.
-
Link for More Details: Ask AI: Hands-On Project
خلاصهش اینه—یه مسیر streamlined به mastery testing. این practices فقط تئوری نیستن؛ همون چیزیه که غولهایی مثل IBM رو نگه میداره تا کدهایی بفرستن که bite back نکنن. دوره کامل رو از Coursera بگیر تا آستینات رو بالا بزنی و labs رو شروع کنی.
درباره خلاصهکننده
من Ali Sol هستم، یه PHP Developer. اگه دوست داری بیشتر آشنا بشیم:
- Website: alisol.ir
- LinkedIn: linkedin.com/in/alisolphp