โลกการเขียนโค้ด ตอน ซามูไรกับสปาตั้น

โลกการเขียนโค้ด ตอน ซามูไรกับสปาตั้น
“Seven Samurai 3” by andy z is licensed under CC BY-NC-SA 2.0

ซามูไรที่ได้รับความไว้วางใจให้แก้ core logic จะมีสัญชาตญาณซามูไร คือแก้ตรงนี้ จับยามสามตาแล้วรู้เลยว่าจะไประเบิดตรงโน้น แล้ววิ่งไปสกัดบั๊กไว้ก่อนความเสียหายจะเกิด (ถ้าเป็นในหนัง ตอนนี้เป็นบทที่บั๊กร้องว่า “มืงรู้ได้ไง?!” :D)

หลังจากที่ผมรู้จัก TDD โลกการเขียนโปรแกรมของผมก็เปลี่ยนไป

นึกถึงกลุ่มชาวบ้านที่กำลังจะต้องต่อสู้กับกองทัพซามูไรที่มีประสบการณ์การรบมาหลายปี อาวุธอะไรก็ไม่มี เลยนั่งเหลาไม้ไผ่ทำหอก ทำโล่ แล้วใช้กลยุทธ์ตั้งแถวหน้ากระดานด้วยโล่ เห็นอะไรระหว่างช่องของโล่ก็แทง ๆ เข้าไป (นึกภาพการรบของชาวสปาตั้นในเรื่อง 300)

“SPARTA 2” by Gabor Richter is licensed under CC BY-NC 4.0

วิธีการนี้ฝึกแค่ 3 เดือนก็ออกรบกับซามูไรที่ฝึกมาหลาย ๆ ปีได้ แต่ทีมเวิร์คต้องแข็งแรงมาก เพราะถ้าโล่ก็แตกคนนึงคือตายทั้งกอง

โล่ของชาวสปาตั้นนั้นไม่ได้เอาไว้ปกป้องตัวเอง แต่เอาไว้ปกป้องเพื่อนที่อยู่ทางซ้าย ในทีมที่ทำ TDD ทุกคนเขียน automate test เพื่อปกป้องเพื่อนในทีม จากการที่ทุกคนพยายาม capture คุณค่าที่ตัวเองกำลังสร้างให้ลูกค้า ทำให้ผมที่อยู่ในทีมกล้าที่แก้โค้ดที่ตัวเองไม่ได้เขียน เพราะเชื่อใจว่า ถ้ามีอะไรพังไป ผมจะเห็นเทสซักตัวแดง จะมีโล่ที่เพื่อนตั้งไว้ ปกป้องผมจากไฟบน production

ตอนผมใช้ชีวิตแบบซามูไร ที่ทุกคนปกป้องตัวเอง อาศัยสัญชาติญาณของตัวเอง ใครอ่อนแอก็แพ้ไป แต่ในการรบแบบชาวสปาตั้น ผมจะมีสมาธิแทงของที่โผล่มาระหว่างช่องของโล่ได้ ก็เพราะไว้วางใจว่าโล่ของเพื่อนจะปกป้องผม ถ้าเราชนะ เราจะชนะไปด้วยกัน เรารู้ว่าถ้าโล่แตกคนนึงก็ตายกันหมด การเขียนโค้ดแบบนี้ทำให้ผมได้รู้จักกับสิ่งใหม่ที่ไม่เคยพบเจอมาก่อนในโลกของซามูไร คือคำว่า “โค้ดของเรา” สำหรับชาวสปาตั้น มันไม่มีโค้ดฉันโค้ดเธอ มีแต่โค้ดของเรา ทุกคนช่วยกันปรับปรุง ดูแล และทำให้มันดีขึ้น ผมจึงได้รู้ว่า collective code ownership ไม่ใช่แค่นิยายปรัมปรา แต่มันมีอยู่จริง

source code สมัยนี้มันโตเร็วมาก มันซับซ้อนมาก และมันเละง่ายมาก ถ้าผมยังใช้ชีวิตอยู่บนวิถีซามูไร ผมนึกไม่ออกเลยว่าจะเอามันอยู่ได้ยังไง ตัองลุยเป็นทีมนี่แหละ มันถึงจะเอาอยู่

สำหรับตัวผมในวันนี้ในฐานะ technical coach แล้ว ผมมอง TDD เป็นความหวัง ผมมีโอกาสได้พบเจอหลายคนที่เคยเข็ดกับความยาก และ ความโดดเดี่ยวของชีวิตซามูไรกลับมามีโอกาสได้สัมผัสกับประสบการณ์การเขียนโค้ดอีกครั้งในบรรยากาศที่แปลกออกไป มันไม่ได้ง่ายขึ้นหรอกนะ แต่การที่รู้ว่าข้างขวาเรามีคนถือโล่ปกป้องอยู่มันทำให้มีกำลังใจจะปกป้องคนที่อยู่ทางซ้าย มีกำลังใจที่จะฝึกฝนเพื่อจะช่วยเพื่อนในทีมได้มากขึ้น แล้ววันยาก ๆ มันก็ยากอย่างมีความหมาย ทำให้ใบหน้าที่เคยเปื้อนแต่ดินกับเหงื่อมันเปื้อนรอยยิ้มขึ้นมา :)

ป.ล.

สำหรับคนที่อ่านแล้วอินมากเลย ตัดสินใจเลยว่าตั้งแต่นาทีนี้ชั้นจะไม่เขียนโค้ดโดยไม่มีเทสอีก ผมอยากชวนให้อ่าน อย่าทำ TDD ถ้า… ก่อนตัดสินใจ

ส่วนคนที่ไม่อินกับนิทาน แต่สนใจว่าทำ TDD นี่มันคุ้มค่าการลงทุนไหม ผมเคยแชร์ ประสบการณ์ TDD ไว้ อาจจะมีประโยชน์ครับ

Read more

ความหมายของที่ซ่อนอยู่ใน Just In Time

ความหมายของที่ซ่อนอยู่ใน Just In Time

วันหนึ่ง มีเด็กน้อยคนหนึ่ง กำลังจะขึ้นเครื่องบิน เด็กน้อยร้องไห้กระจองอแง อยู่ตรง security check เพราะว่าปลาทองที่เค้าจับมาได้ 2 ตัวนั้น ไม่สามารถเอาขึ้นเครื่องได้ เพราะมีน้ำอยู่ ยิ่งเด็กร้องนาน พ่อแม่ก็ยิ่งเครียด แล้วก็

By Chokchai
Boring tasks -> Purpose

Boring tasks -> Purpose

วันก่อน มีเพื่อน ScrumMaster โทรมาให้ช่วยคิดท่า retro สำหรับเติมไฟให้กับทีม (ใครอยากรู้บ้างยกมือขึ้น ^-^/) ก็เลยแชร์ที่นึกออกเร็ว ๆ ไปสองท่า หนึ่งในนั้นคือการโยงจาก boring tasks ไป purpose เริ่มจากให้สมาชิกแต่ละคนเอากระดาษ A4 แนวนอนมาแผ่นนึ

By Chokchai
ทำไมคนมีลูกถึกกันจัง?

ทำไมคนมีลูกถึกกันจัง?

ย้อนกลับไปปี 2013 มันเป็นเวลา 3 เดือนก่อนที่ผมจะตัดสินใจด้วยกันกับภรรยาว่าจะมีลูก แม่ยายคุยกับเราสองคนว่า… แม่ยาย: อายุก็เยอะขึ้นเรื่อยๆแล้วนะ ถ้าจะมี ก็ต้องมีตอนนี้แหละ ช้ากว่านี้ พอแก่ตัวไป มันจะมีผลกับพั

By Chokchai
คิดบวก .. ฝึกได้

คิดบวก .. ฝึกได้

ช่วงนี้อ่านหนังสือ The happiness advantage ของ Shawn Achor อยู่ เป็นหนังสือเล่มนึงที่ชอบมาก เพราะมันทำให้ผมเห็นทั้งประโยชน์ของการมีความสุข และทักษะที่เราสามารถฝึกฝนได้ เพื่อให้แต่ละวันในชีวิตมีความสุขมากขึ้น ทักษะนึงที่จะทำให้เรามีความสุขก็คื

By Chokchai