بازسازی کد ابزار ارزشمندی است، اما نمیتواند به تنهایی مفید باشد. برای انجام درست بازسازی کد، به مجموعهای یکپارچه و قابل اتکا از تستها نیاز دارم تا بتوانم اشتباهات اجتنابناپذیر خود را پیدا کنم. حتی با وجود ابزارهای بازسازی خودکار کد، ناچارم بسیاری از بازسازیهای کد را همچنان از طریق مجموعهای از تستها (test suite) بررسی کنم.
گر به نحوه سپری شدن زمان برنامهنویسان دقت کنید، متوجه میشوید که نوشتن کد در واقع بخش بسیار کوچکی از زمان آنها را تشکیل میدهد. بخشی از زمان برای فهمیدن کاری که باید انجام شود سپری میشود، بخشی از آن هم برای طراحی نرمافزار سپری میشود، اما بیشتر زمان آنها صرف رفع خطا (debug) میشود.
معمولا هر برنامهنویسی خاطرهای دارد از این که کل روزش را برای پیدا کردن یک خطا مشغول بوده است [شما بخوانید سر کار بوده! مترجم]. رفع خطا معمولاً بسیار سریع انجام میشود، اما پیدا کردن خطا واقعا کابوس است.
وقتی خطایی را رفع میکنید، احتمال این که با تغییرات شما، سر و کلهی خطای دیگری پیدا شود همواره وجود دارد. حتی ممکن است است تغییرات شما خطایی را به وجود بیاورد که تا مدتها متوجهی آن نشوید. و وقتی متوجه خطا شدید، بخش زیادی از عمر گرانبار را باید صرف پیدا کردن ریشهی آن و برطرف کردناش کنید.
باید پذیرفت که متقاعد کردن دیگران برای دنبال کردن این مسیر [داشتن کد خودآزما] کار چندان آسانی نیست. نوشتن تست به معنای نوشتن کد اضافهتر از کد اصلی برنامه است. تا زمانی که واقعا تجربه نکرده باشید که داشتن کد خودآزما چقدر میتواند به افزایش سرعت برنامهنویسی شما کمک کند، نوشتن کد خودآزما اصلا توجیهپذیر نیست. و گواه این ادعا این است که بسیاری از افراد نه میدانند چگونه تست بنویسند و نه اصلا به تست نوشتن فکر میکنند.
وقتی تستها دستی باشند به شدت خستهکنندهاند. اما وقتی خودکار باشند، نوشتن تستها واقعا بسیار سرگرمکننده و جذاب است.
گزیده: (عجب گزیدهای)
کیفیت واقعی به این معنی است که مطمئن باشید افراد به کدی که مینویسند افتخار میکنند، فعالانه مشارکت میکنند و آن را از خود میدانند (نسبت به آن حس غرور، مالکیت و مسئولیتپذیری دارند).
لینوس توروالد، سپتامبر ۲۰۰۸
Real quality means making sure that people are proud of the code they write, that they’re involved and taking it personally. Linus Torvalds
دیدگاهتان را بنویسید