DCSIMG
עמוד הבית| חבילות השירות שלנו| חומר חופשי| צור קשר
SCRUM - זה טוב ליהודים? - בלוג היועצים של מיקרוסופט ישראל

בלוג היועצים של מיקרוסופט ישראל

SCRUM - זה טוב ליהודים?

Alik Levin     הערה :פוסט זה הוא של ארכיטקט אורח – יובל לשם. בפוסט יובל נותן סקירה קצרה של SCRUM , מי מרוויח ומי מפסיד מהשיטה וגם כמה טיפים מעשיים. תהנו!

 

ככל מקצוע שמתפתח ומתעדכן, גם עולם התכנות וניהול הפיתוח אינו חף מטרנדים, חידושים והמצאות. בשנים האחרונות, כבשה מתודולוגיית הSCRUM את ליבם של מפתחים ומנהלים רבים בפיתוח. הSCRUM, בקצרה, הוא תהליך פיתוח השונה מהותית מקונספט ה"כתוב מסמך אפיון, מסמך תכנון, מסמך אינטגרציה ובצע אותם" המוכר לכולנו. בSCRUM מדובר בחלוקת המשימה לכמה "ספרינטים" מוגבלי זמן, כאשר כל "ספרינט" כזה מכיל מספר מיקרו משימות המוטלות על הצוות. ישיבות הSCRUM הן יומיות, מהירות, הצוות הוא אמנם רוחבי, אך מתפקד כצוות אורגני בחיי המשימה, וכל ספרינט הוא איטרציה, שבסופה ניתן להשוות בין התוצאות לתכנון, לשנות את הדרישות לספרינט הבא, להחליף, לתעדף וכו'.

אז זה טוב, או לא?

השאלה בכותרת המאמר נשאלה על ידי הCOO, לאחר ניסוי SCRUM ראשון בחברה בה אני עובד כיום. לאחר שצפיתי בכמה תהליכים כאלו הקורים באגפים שונים ובחברות שונות, אפשר לומר, שהתשובה, כמו הרבה שאלות ניהוליות, תלויה את מי שואלים...

אנשי המוצר והUI נהנו מהיכולת לקבל תוצר מהר מהפיתוח, ולתת משוב תוך כדי, ולא בסיום התהליך.

המתכנתים נהנו מחוסר הצורך בתיעוד, מהדינמיות של המשימות, ומההתעסקות נטו בתכנות ופחות באינטגרציה ותיעוד.

אז מי נהנה פחות, תשאלו?

הQA, כמובן.

מדוע הQA נהנים פחות מSCRUM

אחת הבעיות הקשות בSCRUM היא בעיית בקרת איכות הקוד. בעוד שכולם בפיתוח ובמוצר נהנים מהאיטרציות, הקוד לא תמיד "בטוח" מספיק, וכיוון שההתקדמות בSCRUM הינה רוחבית, ולא אורכית (לדוגמה - במקום לכתוב קודם את השרת ואחר כך את הממשק, כותבים FLOW אחד מצד לצד במהלך הספרינט), הבודקים נפגעו מרגרסיות, ומחוסר תשומת לב לבעיות ביצועים (לדוגמה) ולאינטראקציות בין תכונות שונות.

עוד בעיה אופיינית נובעת מעיקרון ה80-20: כיוון שSCRUM מתמקדת במה שכן אפשר להספיק במהלך כל ספרינט, לעתים השלמת ה20% האחרונים תיקח משמעותית יותר זמן מ80 האחוז שלפניהם.

אז איך אפשר להימנע מהבעיות האלו?

ככל הנראה, הפתרון טמון ביכולת לאמץ תהליך בפיתוח לא על פי הספר (ויש די הרבה כאלה כבר), אלא על פי מה שמתאים לכל ארגון ופרויקט. קשה להימנע מניסיון ראשון "לפי הספר" (ונכתבו עד עכשיו כבר כמה ספרים על SCRUM). אבל נסו בליווי התהליך לבדוק מה מתפספס בתהליך.

  • האם זה אינטראקציה בין תכונות?
  • פספוס של תהליכי אינטגרציה?
  • האם צריך להוסיף עוד בדיקות יחידה בין ספרינטים?
  • ומה קורה אחרי שהתהליך מסתיים?
  • ואולי בכלל צריך להתחיל הפוך?

כבר ראיתי קבוצה, שלקחה רק את הפגישות היומיות ולוח המשימות מהמתודולוגיה, וניהלה את הפיתוח על פי השלבים המסורתיים. שיטה זו גם מהווה שיטת מעבר טובה, כיוון שעדיין קיימים מנגנוני הבקרה המסורתיים של הפיתוח.

ולסיכום

תהליכים בפיתוח צריכים להיות דינמיים כמו הטכנולוגיות עצמן. כמו שהפיתרון הטכנולוגי משתנה בהתאם לבעיה, הפתרון התהליכי עשוי להשתנות גם כן. כמובילים בפיתוח, עליכם לשאול את עצמכם באופן תמידי, האם תהליך הפיתוח "טוב ליהודים", ואם לא, שנו אותו!

יובל לשם

איש פיתוח.

 

תוכן התגובה

vvvlad כתב/ה:

אין לי הרבה נסיון ב-Scrum אבל יש הרבה חוסר דיוק בכתבה הזו ואם מישהו רוצה להתעניין בשיטה הזו אז לא כדאי לו לסמוך יותר מדי על הכתוב כאן...

ודרך אגב, Scrum זה מושג ברוגבי ולא ראשי תיבות ולכן לא כותבים SCRUM אלה Scrum.

en.wikipedia.org/.../Scrum

# October 5, 2009 12:40 AM

ארנון רותם-גל-עוז כתב/ה:

הכותב צודק שבד"כ כדאי למצוא נגזרת של התהליך שמתאימה לארגון (זה נכון לכל מתודולוגיה)

יחד עם זאת נראה מהתאור שהגדרת ה"סימנו" בארגון לקויה

אבטחת האיכות צריכה להיות חלק מהתהליך ואם יש דרישות ביצועים גם הן חלק מהתהליך, כנ"ל לגבי שילוב לתוך שאר המוצר

ארנון

# October 5, 2009 6:38 AM

yuval leshem כתב/ה:

שלום, ותודה על התגובות למאמר.

מיכאל - שיטת הScrum שונה משיטת הספירלות, בין השאר בצורה בה היא מתנהלת (ישיבות הScrum הן חלק משמעותי מהתהליך, וגם לוח המשימות), ולא רק במחזורים שלה.

וולאד - אכן הייתי כללי ותמציתי. אם כתבתי משהו לא נכון, אשמח להערות. לגבי Scrum או SCRUM - בכתיבה של עברית עם אנגלית אני לוחץ על שיפט וכותב מילה באנגלית. בפעם הבאה אני מבטיח לדייק.

ארנון - אתה צודק לחלוטין, (אכן אסור לשכוח כלום בשום סוג של תהליך פיתוח) ובכל זאת זה לא הארגון הראשון בו העניינים הספציפים שדיברתי עליהם נופלים.

תודה על ההערות כולם, וחג שמח!

# October 5, 2009 9:00 AM
שלח תגובה

(שדה חובה)  

(שדה חובה)  

(אופציונלי)

(שדה חובה) 

Please add 2 and 1 and type the answer here:


Enter the numbers above: