Learning Object-Oriented Programming, Design and TDD with Pharo

Total Page:16

File Type:pdf, Size:1020Kb

Load more

Learning Object-Oriented Programming, Design and TDD with Pharo Stéphane Ducasse with Damien Pollet September 29, 2017 master @ 86ac50a © 2017 by Stéphane Ducasse with Damien Pollet. This work is licensed under a Creative Commons “Attribution- NonCommercial-NoDerivatives 4.0 International” license. This is a human-readable summary of (and not a substitute for) the license: https://creativecommons.org/licenses/by-nc-nd/4.0/deed.en You are free to: s Share Copy and redistribute the material in any medium or format. The licensor cannot revoke these freedoms as long as you follow the license terms. Under the following terms: b Attribution You must give appropriate credit, provide a link to the license, and indicate if changes were made. You may do so in any reasonable manner, but not in any way that suggests the licensor endorses you or your use. n NonCommercial You may not use the material for commercial purposes. d NoDerivatives If you remix, transform, or build upon the material, you may not distribute the modified material. No additional restrictions You may not apply legal terms or technological measures that legally restrict others from doing anything the license permits. Layout and typography based on the sbabook LATEX class by Damien Pollet. Contents Illustrations viii 1 About this book 1 1.1 A word of presentation ............................ 1 1.2 Structure of the book ............................. 1 1.3 What you will learn .............................. 3 1.4 Typographic conventions ........................... 4 1.5 Videos ..................................... 5 1.6 Thanks ..................................... 5 I Getting in touch with Pharo 2 Pharo syntax in a nutshell 9 2.1 Simplicity and elegance of messages ..................... 9 2.2 Which message is executed first? ....................... 12 2.3 Sending messages to classes ......................... 13 2.4 Local variables and statement sequences ................... 14 2.5 About literal objects .............................. 14 2.6 Sending multiple messages to the same object ................ 15 2.7 Blocks ..................................... 16 2.8 Control structures ............................... 16 2.9 Methods .................................... 17 2.10 Resources ................................... 18 2.11 Conclusion .................................. 19 2.12 Syntax summary ................................ 20 3 Challenge yourself 25 3.1 Challenge: Message identification ....................... 25 3.2 Challenge: Literal objects ........................... 27 3.3 Challenge: Kind of messages ......................... 27 3.4 Challenge: Results ............................... 28 3.5 Challenge: unneeded parentheses ...................... 29 i Contents 4 Developing a simple counter 31 4.1 Our use case .................................. 31 4.2 Create your own class ............................. 32 4.3 Define protocols and methods ........................ 33 4.4 Define a Test Class ............................... 36 4.5 Saving your work ............................... 36 4.6 Adding more messages ............................ 39 4.7 Better object description ........................... 40 4.8 Instance initialization method ......................... 41 4.9 Conclusion ................................... 42 5 Tests, tests and tests 43 5.1 What is a test? ................................. 43 5.2 Test Driven Design ............................... 44 5.3 Why testing is important ........................... 45 5.4 What makes a good test? ........................... 46 5.5 right-Bicep ................................... 47 5.6 SUnit by example ............................... 47 5.7 The SUnit cookbook .............................. 51 5.8 Defining a fixture ............................... 52 5.9 Chapter summary ............................... 53 6 Some collection katas with words 55 6.1 Isogram .................................... 55 6.2 About strings ................................. 56 6.3 A solution using sets .............................. 56 6.4 Defining a test ................................. 58 6.5 Some fun: Obtaining french isograms ..................... 60 6.6 Pangrams ................................... 61 6.7 Handling alphabet ............................... 63 6.8 Identifying missing letters ........................... 64 6.9 Palindrome as exercise ............................ 67 6.10 Conclusion ................................... 67 II About objects and classes 7 Objects and classes 73 7.1 Objects: Entities reacting to messages .................... 73 7.2 Messages and Methods ............................ 75 7.3 An object is a protective entity ........................ 76 7.4 An object protects its data ........................... 77 7.5 With counters ................................. 79 7.6 A class: blueprint or factory of objects .................... 79 7.7 Class and instances are really different .................... 82 7.8 Conclusion ................................... 82 ii Contents 8 Revisiting objects and classes 83 8.1 A simple and naive file system ......................... 83 8.2 Studying a first scenario ............................ 84 8.3 Defining a class ................................ 85 8.4 Printing a directory .............................. 87 8.5 Adding files .................................. 88 8.6 One message and multiple methods ..................... 90 8.7 Objects: stepping back ............................ 91 8.8 Examples of distribution of responsibilities .................. 91 8.9 Important points ............................... 93 8.10 Distribution of responsibilities ........................ 94 8.11 So far so good? Not fully! ........................... 95 8.12 Conclusion ................................... 95 9 Converter 97 9.1 First a test ................................... 97 9.2 Define a test method (and more) ....................... 98 9.3 The class TemperaturConverter ........................ 99 9.4 Converting from Farhenheit to Celsius .................... 100 9.5 About floats .................................. 100 9.6 Printing rounded results ............................ 101 9.7 Building a map of degrees ........................... 102 9.8 Spelling Fahrenheit correctly! ......................... 103 9.9 Adding logging behavior ............................ 104 9.10 Discussion ................................... 106 9.11 Conclusion ................................... 107 10 An electronic wallet 109 10.1 A first test ................................... 109 10.2 Adding coins .................................. 110 10.3 Looking at Bag ................................. 111 10.4 Using a bag for a wallet ............................ 112 10.5 More tests ................................... 113 10.6 Testing money ................................. 113 10.7 Checking to pay an amount .......................... 114 10.8 Biggest coin .................................. 114 10.9 Biggest below a value ............................. 115 10.10 Improving the API ............................... 115 10.11 Coins for paying: First version ......................... 117 10.12 Better heuristics ................................ 118 10.13 Conclusion ................................... 119 11 Crafting a simple embedded DSL with Pharo 121 11.1 Getting started ................................. 121 11.2 Rolling a die .................................. 123 11.3 Creating another test ............................. 123 iii Contents 11.4 Instance creation interface .......................... 124 11.5 First specification of a die handle ....................... 126 11.6 Defining the DieHandle class ......................... 127 11.7 Improving programmer experience ...................... 128 11.8 Rolling a die handle .............................. 128 11.9 About Dice and DieHandle API ........................ 130 11.10 Role playing syntax .............................. 131 11.11 Handle’s addition ............................... 133 11.12 Conclusion ................................... 133 III Sending messages 12 Sending a message is making a choice 137 12.1 Negation: the not message .......................... 138 12.2 Implementing not ............................... 138 12.3 Implementing disjunction ........................... 140 12.4 About ifTrue:ifFalse: implementation ..................... 142 12.5 What is the point? ............................... 143 12.6 Conclusion ................................... 146 IV Looking at inheritance 13 Inheritance: Incremental definition and behavior reuse 149 13.1 Inheritance .................................. 149 13.2 Improving files/directories example design .................. 151 13.3 Transformation strategies ........................... 151 13.4 Factoring out state ............................... 152 13.5 Factoring similar methods ........................... 155 13.6 Sending a message and method lookup ................... 156 13.7 Basic method overrides ............................ 157 13.8 self-send messages and lookup create hooks ................. 158 13.9 Hook/Template explanations ......................... 159 13.10 Essence of self and dispatch .......................... 160 13.11 Instance variables vs. messages ........................ 162 13.12 Conclusion ................................... 162 14 Extending superclass behavior 163 14.1 Revisiting printOn: ............................... 163 14.2 Improving the situation ............................ 164 14.3 Extending superclass behavior using super .................. 166 14.4 Another
Recommended publications
  • Intel Threading Building Blocks

    Intel Threading Building Blocks

    Praise for Intel Threading Building Blocks “The Age of Serial Computing is over. With the advent of multi-core processors, parallel- computing technology that was once relegated to universities and research labs is now emerging as mainstream. Intel Threading Building Blocks updates and greatly expands the ‘work-stealing’ technology pioneered by the MIT Cilk system of 15 years ago, providing a modern industrial-strength C++ library for concurrent programming. “Not only does this book offer an excellent introduction to the library, it furnishes novices and experts alike with a clear and accessible discussion of the complexities of concurrency.” — Charles E. Leiserson, MIT Computer Science and Artificial Intelligence Laboratory “We used to say make it right, then make it fast. We can’t do that anymore. TBB lets us design for correctness and speed up front for Maya. This book shows you how to extract the most benefit from using TBB in your code.” — Martin Watt, Senior Software Engineer, Autodesk “TBB promises to change how parallel programming is done in C++. This book will be extremely useful to any C++ programmer. With this book, James achieves two important goals: • Presents an excellent introduction to parallel programming, illustrating the most com- mon parallel programming patterns and the forces governing their use. • Documents the Threading Building Blocks C++ library—a library that provides generic algorithms for these patterns. “TBB incorporates many of the best ideas that researchers in object-oriented parallel computing developed in the last two decades.” — Marc Snir, Head of the Computer Science Department, University of Illinois at Urbana-Champaign “This book was my first introduction to Intel Threading Building Blocks.
  • Native Implementation of Mutable Value Semantics ICOOOLPS ’21, July 13, 2021, Online

    Native Implementation of Mutable Value Semantics ICOOOLPS ’21, July 13, 2021, Online

    Native Implementation of Mutable Value Semantics Dimitri Racordon Denys Shabalin Daniel Zheng [email protected] [email protected] [email protected] Faculty of Science Google Google University of Geneva Switzerland United States Switzerland Dave Abrahams Brennan Saeta [email protected] [email protected] Google Google United States United States ABSTRACT 1 INTRODUCTION Unrestricted mutation of shared state is a source of many well- Software development continuously grows in complexity, as ap- known problems. The predominant safe solutions are pure func- plications get larger and hardware more sophisticated. One well- tional programming, which bans mutation outright, and flow sen- established principle to tackle this challenge is local reasoning, de- sitive type systems, which depend on sophisticated typing rules. scrbibed by O’Hearn et al. [4] as follows: Mutable value semantics is a third approach that bans sharing in- To understand how a program works, it should be pos- stead of mutation, thereby supporting part-wise in-place mutation sible for reasoning and specification to be confined to and local reasoning, while maintaining a simple type system. In the cells that the program actually accesses. The value the purest form of mutable value semantics, references are second- of any other cell will automatically remain unchanged. class: they are only created implicitly, at function boundaries, and cannot be stored in variables or object fields. Hence, variables can There are two common ways to uphold local reasoning. One never share mutable state. takes inspiration from pure functional languages and immutability. Because references are often regarded as an indispensable tool Unfortunately, this paradigm may fail to capture the programmer’s to write efficient programs, it is legitimate to wonder whether such mental model, or prove ill-suited to express and optimize some al- a discipline can compete other approaches.
  • Ad-Hoc Data Transfer for Android Devices

    Ad-Hoc Data Transfer for Android Devices

    Master Degree Project Ad-hoc Data Transfer for Android Devices Author: Emre Baykal Date: 2013-03-17 Subject: Ad-hoc Data Transfer for Android Devices Level: Master Course code: 5DV00E Abstract With the introduction of smart phones and mobile devices, the rate of technology usage has became widespread. It is very likely to see anyone using mobile device on the street, in the bus, at work, at school or even at home no matter if there is a fully functional computer nearby. Particularly, the usage of smart phones is not just limited to basic communication; they are being used as a technological gadget in our daily lives for years. We can easily reach such applications on different fields e.g. image processing, audio tuning, video editing, voice recognition. With the help of these smart applications we are able to interact with our environment much faster, and consequently make life easier; relatively for sure. Apart from mobile phone industry, sharing and staying connected to our envi- ronment has become very popular. A person who has a mobile phones with latest technology desires to communicate with friends, share feelings instantly, and of course meet new people who understand him well. In this context, technology came to the point where needs of modern human overlaps todays technology. This study aims to provide a basic application to users who has got those needs in terms of sharing and communicating, for maintaining easy and costless solution. This study currently offers prototype application to this problem using WiFi Direct technology, and intends to be pioneer of its field in consequence of existing small numbers of related applications in the market.
  • Static Analysis of Unbounded Structures in Object-Oriented Programs Issue Date: 2012-12-19 Static Analysis of Unbounded Structures in Object-Oriented Programs

    Static Analysis of Unbounded Structures in Object-Oriented Programs Issue Date: 2012-12-19 Static Analysis of Unbounded Structures in Object-Oriented Programs

    Cover Page The handle http://hdl.handle.net/1887/20325 holds various files of this Leiden University dissertation. Author: Grabe, Immo Title: Static analysis of unbounded structures in object-oriented programs Issue Date: 2012-12-19 Static Analysis of Unbounded Structures in Object-Oriented Programs Proefschrift ter verkrijging van de graad van Doctor aan de Universiteit Leiden op gezag van Rector Magnificus prof. mr. P.F. van der Heijden, volgens besluit van het College voor Promoties te verdedigen op woensdag 19 december 2012 klokke 10:00 uur door Immo Grabe geboren te Kiel, Duitsland, in 1979 Promotiecommissie Promotoren: Prof. Dr. F.S. de Boer Universiteit Leiden Prof. Dr. M. Steffen Universitetet i Oslo Overige Leden: Prof. Dr. E. Broch Johnsen Universitetet i Oslo Prof. Dr. F. Arbab Universiteit Leiden Prof. Dr. J.N. Kok Universiteit Leiden Dr. M. Bonsangue Universiteit Leiden The work in this thesis has been carried out at the Christian-Albrechts- -Universit¨at zu Kiel, the Centrum Wiskunde & Informatica (CWI), and the Universiteit Leiden. The research was partially funded by the EU-project IST- 33826 Credo: Modeling and analysis of evolutionary structures for distributed services, the EU-project FP7-231620 HATS: Highly Adaptable and Trustwor- thy Software using Formal Methods, and the German-Norwegian DAAD-NWO exchange project Avabi (Automated validation for behavioral interfaces of asynchronous active objects). Copyright c 2012 by Immo Grabe Cover design by Immo Grabe. Printed by: Proefschriftmaken.nl || Uitgeverij BOXPress Published by: Uitgeverij BOXPress, Oisterwijk ISBN: 978-90-8891-154-75 Contents 1 Introduction 1 I Object Creation 5 2 Abstract Object Creation 7 2.1 Introduction............................
  • Braceforce: a Middleware to Enable Sensing Integration in Mobile Applications for Novice Programmers

    Braceforce: a Middleware to Enable Sensing Integration in Mobile Applications for Novice Programmers

    BraceForce: A Middleware to Enable Sensing Integration in Mobile Applications for Novice Programmers Xi Zheng, Dewayne E. Perry, Christine Julien The Center for Advanced Research in Software Engineering Mobile and Pervasive Computing Lab The University of Texas at Austin [email protected],[email protected],[email protected] ABSTRACT demonstrating the feasibility of applications, the develop- Even as the use of sensor networks to support mobile ap- ment of support services such as routing protocols or energy- plications grows, our ability to seamlessly and efficiently in- saving algorithms, or on advancement of hardware platforms corporate sensor network capabilities into our mobile ap- and operating systems. Little focus has been applied to ef- plications remains astoundingly difficult. Today, accessing fective development support for applications that integrate remote sensing data and integrating this data into the adap- the capabilities of networked sensing platforms in easy to use tive behavior of a dynamic user-facing mobile application re- and extensible ways. In addition to the variety of data for- quires interacting with multiple platforms, languages, data mats, communication technologies, and programming plat- formats, and communication paradigms. We present Brace- forms a developer must tackle, mobile applications also re- Force, an open and extensible middleware that allows de- quire handling network dynamics and energy constraints. velopers to access the myriad remote sensing capabilities This paper introduces BraceForce, a middleware for mo- inherent to today's mobile computing spaces (where mo- bile application development that simplifies the development, bile devices and sensors are closely integrated) using very deployment, and debugging of mobile applications.
  • A Middleware Enabling Novice Programmers to Integrate Sensing in CPS Applications

    A Middleware Enabling Novice Programmers to Integrate Sensing in CPS Applications

    BraceForce: A Middleware Enabling Novice Programmers to Integrate Sensing in CPS Applications Xi Zheng, Dewayne E. Perry, Christine Julien ([email protected], [email protected], [email protected]) The Center for Advanced Research in Software Engineering Mobile and Pervasive Computing Lab, Electrical and Computer Engineering The University of Texas at Austin TR-ARiSE-2013-003 © Copyright 2013 The University of Texas at Austin BraceForce: A Middleware Enabling Novice Programmers to Integrate Sensing in CPS Applications Xi Zheng, Dewayne E. Perry, Christine Julien The Center for Advanced Research in Software Engineering Mobile and Pervasive Computing Lab The University of Texas at Austin [email protected],[email protected],[email protected] ABSTRACT forms with little potential for portability to other plat- Even as the use of sensor networks to support CPS forms or integration with other sensors. Debugging CPS applications grows, our ability to seamlessly and effi- applications that inherently integrate with a physical ciently incorporate sensor network capabilities remains environment requires not only the aforementioned in- astoundingly difficult. Today, accessing remote sensing tegration of the application with sensing but also the data and integrating this data into the adaptive behav- use of a testing harness that, at debugging time, ac- ior of a dynamic user-facing CPS application requires in- cesses sensed data about the physical environment for teracting with multiple sensor platform languages, data the purposes of validating the actions of the applica- formats, and communication channels and paradigms. tion. Integrating sensing for application and debugging We present BraceForce, an open and extensible middle- support in a way that is easy, flexible, and portable is ware that allows developers to access the myriad remote essential for supporting CPS application development.
  • Android Chess: a Real Time Collaborative Software Application for Multiple Mobile Clients

    Android Chess: a Real Time Collaborative Software Application for Multiple Mobile Clients

    CALIFORNIA STATE UNIVERSITY, NORTHRIDGE Android Chess: A Real Time Collaborative Software Application for Multiple Mobile Clients A thesis submitted in partial fulfillment of the requirements for the degree of Master of Science in Software Engineering By Eduard S. Sarkisov December 2011 The thesis of Eduard S. Sarkisov is approved: Shan Barkataki, Ph. D. Date Jack Alanen, Ph.D. Date Richard Covington, Ph. D., Chair Date California State University, Northridge ii Table of Contents Signature Page .................................................................................................................... ii Abstract .............................................................................................................................. vi Chapter 1: OBJECTIVE AND GOALS ............................................................................. 1 Chapter 2: PROBLEM DESCRIPTION ............................................................................. 3 Chapter 3: BACKGROUND............................................................................................... 5 3.1 Why Chess................................................................................................................. 5 3.2 Why Aandroid & Java. .............................................................................................. 5 3.3 Initial Research .......................................................................................................... 6 3.4 Starting Point ............................................................................................................
  • Data Structures

    Data Structures

    KARNATAKA STATE OPEN UNIVERSITY DATA STRUCTURES BCA I SEMESTER SUBJECT CODE: BCA 04 SUBJECT TITLE: DATA STRUCTURES 1 STRUCTURE OF THE COURSE CONTENT BLOCK 1 PROBLEM SOLVING Unit 1: Top-down Design – Implementation Unit 2: Verification – Efficiency Unit 3: Analysis Unit 4: Sample Algorithm BLOCK 2 LISTS, STACKS AND QUEUES Unit 1: Abstract Data Type (ADT) Unit 2: List ADT Unit 3: Stack ADT Unit 4: Queue ADT BLOCK 3 TREES Unit 1: Binary Trees Unit 2: AVL Trees Unit 3: Tree Traversals and Hashing Unit 4: Simple implementations of Tree BLOCK 4 SORTING Unit 1: Insertion Sort Unit 2: Shell sort and Heap sort Unit 3: Merge sort and Quick sort Unit 4: External Sort BLOCK 5 GRAPHS Unit 1: Topological Sort Unit 2: Path Algorithms Unit 3: Prim‘s Algorithm Unit 4: Undirected Graphs – Bi-connectivity Books: 1. R. G. Dromey, ―How to Solve it by Computer‖ (Chaps 1-2), Prentice-Hall of India, 2002. 2. M. A. Weiss, ―Data Structures and Algorithm Analysis in C‖, 2nd ed, Pearson Education Asia, 2002. 3. Y. Langsam, M. J. Augenstein and A. M. Tenenbaum, ―Data Structures using C‖, Pearson Education Asia, 2004 4. Richard F. Gilberg, Behrouz A. Forouzan, ―Data Structures – A Pseudocode Approach with C‖, Thomson Brooks / COLE, 1998. 5. Aho, J. E. Hopcroft and J. D. Ullman, ―Data Structures and Algorithms‖, Pearson education Asia, 1983. 2 BLOCK I BLOCK I PROBLEM SOLVING Computer problem-solving can be summed up in one word – it is demanding! It is an intricate process requiring much thought, careful planning, logical precision, persistence, and attention to detail.
  • On-Premises Developer Guide

    On-Premises Developer Guide

    Informatica® Address Verification (On- Premises) 6.1.0 On-Premises Developer Guide Informatica Address Verification (On-Premises) On-Premises Developer Guide 6.1.0 September 2020 © Copyright Informatica LLC 1993, 2020 This software and documentation are provided only under a separate license agreement containing restrictions on use and disclosure. No part of this document may be reproduced or transmitted in any form, by any means (electronic, photocopying, recording or otherwise) without prior consent of Informatica LLC. U.S. GOVERNMENT RIGHTS Programs, software, databases, and related documentation and technical data delivered to U.S. Government customers are "commercial computer software" or "commercial technical data" pursuant to the applicable Federal Acquisition Regulation and agency-specific supplemental regulations. As such, the use, duplication, disclosure, modification, and adaptation is subject to the restrictions and license terms set forth in the applicable Government contract, and, to the extent applicable by the terms of the Government contract, the additional rights set forth in FAR 52.227-19, Commercial Computer Software License. Informatica, the Informatica logo, and any other Informatica-owned trademarks that appear in the document are trademarks or registered trademarks of Informatica LLC in the United States and many jurisdictions throughout the world. A current list of Informatica trademarks is available on the web at https://www.informatica.com/ trademarks.html. Other company and product names may be trade names or trademarks of their respective owners. Portions of this software and/or documentation are subject to copyright held by third parties, including without limitation: Copyright DataDirect Technologies. All rights reserved. Copyright © Sun Microsystems. All rights reserved.
  • The Tutor-In-The-Loop Model for Formative Assessment

    The Tutor-In-The-Loop Model for Formative Assessment

    The Tutor-in-the-Loop Model for Formative Assessment Von der Fakultät für Mathematik, Informatik und Naturwissenschaften der RWTH Aachen University zur Erlangung des akademischen Grades eines Doktors der Naturwissenschaften genehmigte Dissertation vorgelegt von Diplom-Informatiker Daniel Chu Herding aus Münster (Westf.) Berichter: Prof. Dr. Ulrik Schroeder Prof. Dr. Christian Spannagel Tag der mündlichen Prüfung: 21. März 2013 Diese Dissertation ist auf den Internetseiten der Hochschulbibliothek online verfügbar. iii Acknowledgement Parts of the research described in this thesis has been carried out within the SAiL-M project (Semi-automatic assessment of inividual learning processes in mathematics)1. The project was funded by the German Federal Ministry of Education and Research (Bun- desministerium für Bildung und Forschung, BMBF) in the support program “Hochschulfor- schung als Beitrag zur Professionalisierung der Hochschullehre – Zukunftswerkstatt Hochschul- lehre” (“Higher Education Research as a Contribution to the Professionalization of Higher Education – Future Workshop Higher Education”). Project management organisation was provided by DLR2. SAiL-M was a joint research project of these partners: • Ludwigsburg University of Education • Karlsruhe University of Education • Weingarten University of Education • RWTH Aachen University 1 SAiL-M project: sail-m.de/en/. 2 DLR – Professionalization of Higher Education: http://www.dlr.de/pt_zwh. v Abstract Closed exercise types like multiple-choice tests are widespread in higher education, es- pecially for purposes of summative assessment. However, they cannot be considered learner-centric because they do not allow individual solutions. In contrast, assessing open-ended tasks is considerably more complex. Intelligent tutoring systems (ITS) aim at giving individual feedback fully autonomously, but due to their high development cost, they are available only for few domains.
  • A Framework for Supporting Automatic Simulation Generation from Design

    A Framework for Supporting Automatic Simulation Generation from Design

    UNIVERSITY OF NEWCASTLE UPON TYNE DEPARTMENT OF COMPUTING SCIENCE UN IVERS ITY OF NEWCASTLE A Framework for Supporting Automatic Simulation Generation from Design by Leonardus Budiman Arief Ph.D. Thesis July 2001 Abstract Building a new software system requires careful planning and investigation in order to avoid any problems in the later stages of the development. By using a universally accepted design notation such as the Unified Modeling Language (UML), ambiguities in the system specification can be eliminated or minimised. The aspect that frequently needs to be investigated before the implementation stage can be commenced concerns the proposed system’s performance. It is necessary to predict whether a particular design will meet the performance requirement - i.e. is it worth implementing the system - or not. One way to obtain this performance prediction is by using simulation programs to mimic the execution of the system. Unfortunately, it is often difficult to transform the design into a simulation program without some sound knowledge of simulation techniques. In addition, new simulation programs need to be built each time for different systems - which can be tedious, time consuming and error prone. The currently available UML tools do not provide any facilities for generating simulation programs automatically from UML specifications. This shortcoming is the main motivation for this research. The work involved here includes an investigation of which UML design notations can be used; the available simulation languages or environments for running the simulation; and more importantly, a framework that can capture the simulation information from UML design notation. Using this framework, we have built tools that enable an automatic transformation of a UML design notation into a simulation program.