Microsoft PowerPoint - 07_tdd.ppt

מסמכים קשורים
Microsoft PowerPoint - 07_tdd.ppt

מבחן בפיתוח מערכות תוכנה בשפת Java ( )

הגשה תוך שבוע בשעת התרגול

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

Homework Dry 3

שבוע 4 סינטקס של HACK ASSEMBLY ניתן להשתמש בשלושה אוגרים בלבד:,A,D,M כולם בעלי 16 ביטים. M אינו אוגר ישיר- הוא מסמן את האוגר של ה RAM שאנחנו מצביעים ע

סדנת תכנות ב C/C++

תורת הקומפילציה

Slide 1

Slide 1

Microsoft PowerPoint - lec10.ppt

PowerPoint Presentation

משימה תכנית המתרגמת קטעי טקסט לשפה אחרת הקלט: קובץ המכיל את קטעי הטקסט וכן את השפה אליה רוצים לתרגם תרגול מס' 4: המתרגם שימוש במחלקות קיימות תכנות מתק

יוםראשון, 02 ליולי 2014 סמסטר סוף מבחן )236703( עצמים מונחה תכנות - א' מועד 2014, אביב סמסטר קמחי יחיאל ד"ר מרצה: מסינג מיטל עבדאלקאדר, כרם גלעד, ערן

תרגול מס' 4: המתרגם שימוש במחלקות קיימות מחרוזות, קבצים, וקבלת קלט מהמשתמש

מהוא לתכנות ב- JAVA מעבדה 3

תרגול 1

מבוא לתכנות ב- JAVA תרגול 11

תכנות מונחה עצמים א' – תש"ע

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

Microsoft PowerPoint - rec3.ppt

Microsoft Word - c_SimA_MoedB2005.doc

PowerPoint Presentation

מבוא למדעי המחשב

מבוא למדעי המחשב - חובלים

PowerPoint Presentation

Overview of new Office 365 plans for SMBs

Microsoft Word B

אוניברסיטת בן גוריון בנגב תאריך המבחן: שקולניק אלכסנדר שם המרצה: מר בשפת JAVA מבוא לתכנות מבחן ב: מס' הקורס : הנדסת תעשיה וניהול מ

מצגת של PowerPoint

Slide 1

מבוא למדעי המחשב

PowerPoint Presentation

PowerPoint Presentation

מבוא למדעי המחשב

2013/14 אוניברסיטת חיפה מבוא למדעי מחשב, מעבדה מטרת המעבדה: לתרגל את המעבר מאלגוריתם לקוד C כמה שיותר. הוראות:.1.2 ניתן לעבוד ביחידים או בזוגות. (יש מ

מבוא לתכנות ב- JAVA תרגול 7

Microsoft PowerPoint - L01-n.ppt

מבחן סוף סמסטר מועד ב 28/10/08 מרצה אחראית: דר שירלי הלוי גינסברג מתרגלים: גלעד קותיאל, גדי אלכסנדרוביץ הוראות: א. בטופס המבחן 6 עמודים (כולל דף זה) ו

שאלהIgal : מערכים דו מימדיים רקורסיה:

PowerPoint Presentation

Slide 1

PowerPoint Presentation

PowerPoint Presentation

שאלהIgal : מערכים דו מימדיים רקורסיה:

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

תרגול מס' 1

פתרון מוצע לבחינת מה"ט ב_שפת c מועד ב אביב תשע"ט, אפריל 2019 מחברת: גב' זהבה לביא, מכללת אורט רחובות שאלה מספר 1 מוגדרת מחרוזת המורכבת מהספרות 0 עד 9.

מבחן סוף סמסטר מועד א 15/02/08 מרצה אחראית: דר שירלי הלוי גינסברג מתרגלים: גלעד קותיאל, דניאל גנקין הוראות: א. בטופס המבחן 7 עמודים ו 4 דפי נוסחאות. ב

Microsoft PowerPoint - Lecture1

Slide 1

אתגר קוביות מחייכות תכולה: 12 קוביות חוברת הוראות ופתרונות ספרון הכולל 60 חידות חידות בדרגות קושי שונות תפיסה חזותית וחשיבה לוגית הקדמה המשחק פרצופים

Microsoft PowerPoint - rec8.ppt

התגוננות בפני כוחות האופל

מבוא למדעי המחשב

Microsoft Word - pitaron222Java_2007.doc

Microsoft PowerPoint - lec2.ppt

מבחן 7002 פרטים כלליים מועד הבחינה: בכל זמן מספר השאלון: 1 משך הבחינה: 3 שעות חומר עזר בשימוש: הכל )ספרים ומחברות( המלצות: קרא המלצות לפני הבחינה ובדי

Microsoft Word - דוגמאות ב

מבוא למדעי המחשב

תכנות דינמי פרק 6, סעיפים 1-6, ב- Kleinberg/Tardos סכום חלקי מרחק עריכה הרעיון: במקום להרחיב פתרון חלקי יחיד בכל צעד, נרחיב כמה פתרונות אפשריים וניקח

Slide 1

Slide 1

Slide 1

פייתון

שקופית 1

מספר מחברת: עמוד 1 מתוך 11 ת"ז: תשע"א מועד ב סמסטר א' תאריך: 00:11 שעה: 0 שעות הבחינה: משך כל חומר עזר אסור בשימוש בחינה בקורס: מבוא למדעי ה

מבוא למדעי המחשב

TEL- AVIV UNIVERSITY SACKLER FACULTY OF MEDICINE THE STANLEY STEYER SCHOOL OF HEALTH PROFESSIONS DEPARTMENT OF NURSING אוניברסיטת תל-אביב הפקולטה לרפו

אוניברסיטת חיפה החוג למדעי המחשב.5.6 מבוא למדעי המחשב סמסטר א' תשע"ז בחינה סופית מועד א', מרצה: שולי וינטנר מתרגלים: סמאח אידריס, ראמי עילבו

מקביליות

eriktology The Prophets Book of 1 st Kings [1]

Tutorial 11

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

PowerPoint Presentation

eriktology The Writings Book of Proverbs [1]

eriktology The Writings Book of Psalms [1]

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

eriktology The Prophets Book of Isaiah [1]

Slide 1

Slide 1

מספר זהות: סמסטר ב' מועד א' תאריך: 11102/4// שעה: 9:22 משך הבחינה: 3 שעות חומר עזר: אין מותר השימוש במחשבון פשוט בחינה בקורס: מבני נתונים מרצה: הדר בי

שאלהIgal : מערכים דו מימדיים רקורסיה:

פתרון 2000 א. טבלת מעקב אחר ביצוע האלגוריתם הנתון עבור הערכים : פלט num = 37, sif = 7 r האם ספרת האחדות של sif שווה ל- num num 37 sif 7 שורה (1)-(2) (

מבוא למדעי המחשב - חובלים

שעור 6

PowerPoint Presentation

תמליל:

המצגת מבו ס סת על הספר: Test-Driven Development By Example By Kent Beck Publisher: Addison Wesley Date: November 08, 2002 ISBN: 0-321-14653-0 Pages: 240 תכנות מונחה בדיקות (Test Driven Development) אוהד ברזילי extreme Programming ערכים ומיומנויות שהתגלו היום בשיעור XP כרקע לפיתוח גישת התכנות מונחה הבדיקות לקיצוניות כאפקטיבים נלקחים עקרונות הגישה דוגמא מודרכת - Fibonacci טעימה מתוך דוגמא מודרכת Money סיכום אומץ פשטות תקשורת משוב אינטגרציה בדיקות גרסא 4 3 Collective ownership Pair programming Sustainable pace On-site customer Planning game Metaphor 4 ערכים המתודולוגיה מושתתת על 4 ערכים: משוב (feedback) פשטות (Simplicity) תקשורת (Communication) אומץ (Courage) מערכים אלו נגזרות 12 מיומנויו ת תוכנה 12 מיומנ ו י ות Code/Technical Perspective Refactoring Simple design Coding standards Test First Continuous integration Small releases Human/Social Perspective 6 5

בדיקות תחילה The 12 XP practices קוד נקי שעובד works) (clean code that קוד חדש נכתב רק אחרי שבדיקה אוטומטית נכשלת הסרת כפילויות השלכות טכניות התכן (design) מלווה בקידוד המתכנת כותב את הבדיקות קומפילציה מהירה צימוד חלש בין רכיבים 8 Source: Beck, K. (2000). extreme Programming explained, Addison Wesley. Note: nothing is new; gathering the practices together is XP uniqueness 7 ירוק - שכתב אומץ אדום If pain is nature's way of saying "Stop!" then fear is nature's way of saying "Be careful." אדום כתוב בדיקה שנכשלת (אולי אפילו לא עוברת קומפילציה) ירוק תעשה במהירות שהבדיקה תצליח (תוך אולי שחיטת פרות קדושות של עקרונות תכנות נכונים) שכתוב (refactoring) הסר את הכפילויות בקוד שכראה הכנסת בשלב הקודם 10 9 שלבי העבודה Fibonacci 1. Quickly add a test. 2. Run all tests and see the new one fail. 3. Make a little change. 4. Run all tests and see them all succeed. 5. Refactor to remove duplication. נתחיל בדוגמא פשוטה ברצוננו לכתוב פונקציה המחשבת איבר בסדרת פיבונאצ'י נכתוב את הפונקציה בגישה של Test First 12 11

איך מתחילים? (תסריטים) תעשה שיתקמפל נוסיף קוד מינימ לי כדי לפתור את בעיית הקומפילציה int fib(int i){ return 0; נריץ... (את קוד הבדיקה) ירוק התכנות שלנו מונע מסיפורים "נרצה שאפשר יהיה לבצע במערכת..." מה נרצה שתעשה הפונקציה? ניצור מחלקה ששם יישב קוד הבדיקה public class TestFib extends TestCase { assertequals(0, fib(0)); 14 13 נוסיף עוד בדיקה תעשה שיהיה ירוק נוסיף קוד מינימלי כדי להפוך את הפס לירוק if (n == 0) return 0; return 1; נריץ... (את קוד הבדיקה) ירוק 16 אפשר להוסיף עוד מתודת בדיקה חדשה: public void testfibonacciofoneisone() { assertequals(1, fib(1)); assertequals(0, fib(0)); assertequals(1, fib(1)); אנחנו נסתפק ב: נריץ... אדום 15 18 הסרת כפילויות הכפילויות הפעם הן בבדיקה (ולא בקוד) נסיר אותן (refactoring) int cases[][]= {{0,0,{1,1; for (int i= 0; i < cases.length; i++) assertequals(cases[i][1], fib(cases[i][0])); נוודא שלא הרסנו כלום (או שלא גילינו באג חדש)... ירוק נוסיף עוד בדיקה קל להוסיף את הבדיקה בפונקציה הבדיקה המשוכתבת (6 הקשות מקלדת בלבד!) int cases[][]= {{0,0,{1,1,{2,1; for (int i= 0; i < cases.length; i++) assertequals(cases[i][1], fib(cases[i][0])); fib(2) == 1 נריץ... עדיין ירוק 17

ואחת לשנה הבאה תעשה שיהיה ירוק נוסיף קוד מינימלי כדי להפוך את הפס לירוק רק בשביל להיות בטוחים שסיימנו... return 2; 20 int cases[][]= {{0,0,{1,1,{2,1,{3,2; for (int i= 0; i < cases.length; i++) assertequals(cases[i][1], fib(cases[i][0])); נריץ... אדום (שזה טוב, גילינו באג!) ירוק שכתוב: מאיפה הגיע ה- 2? זהו בעצם 1+1 fib(2) == 1 fib(3) == 2 נריץ... fib(2) == 1 fib(3) == 2 19 שכתוב שכתוב return fib(n-1) + fib(n-2); if (n == 1) return 1; return fib(n-1) + fib(n-2); 22 return 1 + 1; return fib(n-1) + 1; קיבלנו: ה- 1 הראשון הוא בעצם fib(n-1) ה- 1 השני הוא בעצם ה- 1 השני הוא בעצם fib(n-2) נכליל עבור,fib(2) וסיימנו fib(n-2) 21 Instrument IBM GE דוגמא נוספת דוגמא מודרכת לאחר כמה שנים נתבקש המתכנת לתמוך בעוד מטבעות (פרט ל (Dollar Instrument Shares Price Total IBM 1000 25 USD 25000 USD Novartis 400 150 CHF 60000 CHF Total 65000 USD From To Rate CHF USD 1.5 מערכת אמיתית לניהול תיק השקעות c2.com/doc/oopsla91.html נרצה לממש מחלקה שמייצגת כסף Shares 1000 400 Price 25 100 Total Total 25000 40000 65000 24 23

מתחילים תרגיעי את הקומפיילר שלך No class Dollar No constructor No method times(int) No field amount class Dollar { void times(int multiplier) { התכנות שלנו מונע מסיפורים (תסריטים) "נרצה שאפשר יהיה לבצע במערכת..." בשלב ראשון נתאר את התסריט במונחים של עצמים מטיפוס Dollar public void testmultiplication() { Dollar five= new Dollar(5); five.times(2); assertequals(10, five.amount); ה- test מרמז על design נוראי: public fields side-effects integers for monetary amounts 26 25 ירוק עכשיו { Dollar class תיקון מינימלי מה יש לשכתב כאן? אין בקוד שכפול קוד אבל יש תלות בין קוד הבדיקה והקוד הנבדק אם ה- 10 היה נכתב כ- 5*2 התלות היתה בולטת יותר amount= 5 * 2; void times(int multiplier) { int amount = =10 5 * 2 ; 28 27 amount= amount * multiplier; amount= amount * 2; איך ניפטר מה-? 2 איך ניפטר מה-? 2 amount מופיע פעמיים 30 29

איך ניפטר מה-? 2 amount מופיע פעמיים סיכום ביניים Made a list of the tests we knew we needed to have working Told a story with a snippet of code about how we wanted to view one operation Made the test compile with stubs Made the test run by committing horrible sins Gradually generalized the working code, replacing constants with variables Added items to our to-do list rather than addressing them all at once amount *= multiplier; 32 31 Write a test בהקשר כללי יותר Think about how you would like the operation in your mind to appear in your code. You are writing a story. Invent the interface you wish you had. Write a test. Make it run Make it right Include all of the elements in the story that you imagine will be necessary to calculate the right answers. 34 33 Make it right Make it run Now that the system is behaving, put the sinful ways of the recent past behind you Step back onto the straight and narrow path of software righteousness Remove the duplication that you have introduced, and get to green quickly Quickly getting that bar to go to green dominates everything else If a clean, simple solution is obvious, then type it in If the clean, simple solution is obvious but it will take you a minute, then make a note of it and get back to the main problem, which is getting the bar green in seconds This shift in aesthetics is hard for some experienced software engineers They only know how to follow the rules of good engineering Quick green excuses all sins. But only for a moment 36 35

רוצים עוד? עוד TDD עוד XP 37