340 likes | 449 Views
CS427: Software Engineering I. Darko Marinov (slides from Ralph Johnson). Midterm exam. You can get graded exams from TAs Feel free to ask if you think we made mistake Grades almost normally distributed. Comment on midterm exam.
E N D
CS427:Software Engineering I Darko Marinov (slides from Ralph Johnson)
Midterm exam • You can get graded exams from TAs • Feel free to ask if you think we made mistake • Grades almost normally distributed CS427
Comment on midterm exam • COCOMO question is picking details from the reading; is it really like that? • One correct answer, using formula E ~ sizeP • This is not exponential, not E ~ Psize • Another correct answer, common sense • E(200KLOC) = 2*E(100KLOC) + E(integration) • Common sense can lead to incorrect answers • E(200KLOC) ≤ 2*E(100KLOC) CS427
Project info • Groups formed (any volunteers for 10?) • Grading: You are graded on how well you follow your process (you decide XP or RUP) • You must know it • You must follow it • You must prove you follow it • Make a log of what you do every day • HW2 is due next Tuesday, Oct 24 • Use cases and UML diagrams for your project CS427
Topics • Covered • Requirements • Some specification • Some design • Today: specification and design • Chapters 9, 10, 11 of Hamlet and Maybee • Formal specs • Tests as specs • Specs vs. design CS427
Use formal specifications (1) • To develop models of parts of system • Finite state machines, abstract data types • To develop model of one aspect of system • Data-flow diagram, security, architecture • To learn how to think about problem • Pre/post conditions, invariants • Set, sequence, mappings (generic ADTs) CS427
Use formal specifications (2) • For particular kinds of applications • Compilers • Grammar • Denotational semantics • Safety critical CS427
What you should know about formal methods • Chapter 10 of Hamlet and Maybee • Be familiar with the controversy • Don’t need to learn Prolog CS427
Tests as specifications • Formal specification (entire space) • Balance after you add money to an account will be the balance beforehand plus the amount of money you added • Test (one point in the space) • Create account with balance of $100 • Add $20 to account • Account has balance of $120 CS427
Advantages of tests as specs • Concrete, easy to understand • Don’t need new language • Easy to see if program meets the specs • Making tests forces you to talk to customer and learn the problem • Making tests forces you to think about design of system (classes, methods, etc.) CS427
Disadvantages of tests as specs • Hard to test that something can’t happen • Can’t withdraw more money than you have in the system • Can’t break into the system • Can’t cause a very long transaction that hangs the system • Tends to be verbose • Sampling many points from the space CS427
JUnit • www.junit.org • A test is a method whose name starts with “test” in a subclass of TestCase • Version 4.0 also allows @Tets annotations • Calls methods (defined in TestCase) like • assertEqual(object1, object2) • assertTrue(boolean) CS427
Testing Student and Course public void testStudentCreation() { Student s = new Student("Marvin Minsky"); assertTrue(s.getName().equals("Marvin Minsky")); } or public void testStudentCreation() { Student s = new Student("Marvin Minsky"); assertEqual(s.getName(), "Marvin Minsky"); } CS427
Normal test • Set up “test fixture” • Call method that is being tested • Assert that result is correct CS427
More involved example public void testAddingStudent() { Course c = new Course("Tourism 101"); Student s = new Student("Donald Knuth"); c.addStudent(s); assertEquals(c.students().size(), 1); assertEquals(c.students().elementAt(0), s); } CS427
Tests as specifications • Tests show how to use the system • Tests need to be readable • Need comments that describe their purpose • Keep short, delete duplication CS427
Design Verb • To conceive or plan out in the mind • To make a drawing, pattern, or sketch of CS427
Life-cycle • Requirements capture • Specification • Design • Implementation CS427
A good design • Satisfies requirements • Easy to implement • Easy to understand • Easy to change • Easy to check for correctness • Is beautiful (welcome [back] to Software Engineering) CS427
Keep It Simple (S) • Einstein: “Everything should be as simple as possible, but no simpler.” • Saint-Exupery: “A design is perfect not when there is nothing to add, but when there is nothing to take away.” • Gates: “Measuring a program by the number of lines of code is like measuring an airplane by how much it weighs.” CS427
Keep it simple • Avoid duplication • Eliminate unnecessary features/code • Hide information • No surprises (follow standards) CS427
Davis Design Principles (1) • Don’t reinvent the wheel • Search the web. Read the book. Talk to experts. • Exhibit uniformity and integration • Make parts as similar as possible • Coding standard • Standard names CS427
Davis Design Principles (2) • Minimize the intellectual distance between the software and the problem as it exists in the real world • Use same names as your customers • Use same models as your customers • Structure the design to accommodate change CS427
Davis • The design should be structured to degrade gently, even when aberrant data, events, or operating conditions are encountered • The design should be assessed for quality as it is being created, not after the fact • The design should be reviewed to minimize conceptual errors CS427
Many things to design • Company • System that uses program • Interface to program • Interface of module within program • Procedure • Database CS427
Design • Process of eliminating “misfits” • Find something wrong and fix it • Good design requires being able to spot something that is wrong CS427
What can go wrong? • Too complex - can’t understand • Users can’t understand • Programmers can’t understand • Too slow • Wrong features • Too hard to add new features • Not compatible CS427
Too hard to add new features • Usually because problem is decomposed improperly • Design decisions should be hidden • Only one module should know about design decision • Changing that decision requires changing only one module CS427
Separate user interface • Separate user interface from program logic • UI changes frequently • It is easier to change UI if it is separate • UI experts can be non-programmers • Can provide several UIs for one system CS427
Automated tests • UI hard to test • Separate UI from program logic and write automated tests for program logic • UI first? • No, design program logic first and write tests for it • Database first? • No, design program logic first and write tests for it. Then design database and rewrite to use it CS427
Summary • Fuzzy boundaries between • Analysis and design • Design and implementation • Design is problem solving • It helps to know a lot of solutions CS427
Project advice repeated • You are graded on how well you follow your process. • You must know it. • You must follow it. • You must prove you follow it. • Make a log of what you do every day. CS427
Next time • Read chapters 13 and 14 of Hamlet and Maybee CS427