Introducing Systems Analysis Design Development

32
Introducing Systems Analysis, Design & Development Concepts Shafiul Azam Chowdhury

description

 

Transcript of Introducing Systems Analysis Design Development

Page 1: Introducing Systems Analysis Design Development

IntroducingSystems Analysis, Design &

Development Concepts

Shafiul Azam Chowdhury

Page 2: Introducing Systems Analysis Design Development

Task: Build a Simplest Accounting S/W

• You’ve been offered to build a very basic accounting software for Bangoo Banks Inc.– You’ll need to collaborate with 3-4 other

developers.– You’ll receive handsome amount of cash for full

functional software!– Deadline: very, very strict. Say, couple of months?

Page 3: Introducing Systems Analysis Design Development

What are you going to do?

• Divide the total project in visible sections, say: – User Accounts– Human Resource– Accounting– Etc…

• And started asking questions to your clients how they want the program behave, design database…

Page 4: Introducing Systems Analysis Design Development

All four developers started coding as fast as you can to maintain deadline.

Page 5: Introducing Systems Analysis Design Development

After some days… you felt like integrating your works?

• But you figured out you need a change in some part, you could change it, but others’ code can break?

• You hardly understand what your friend means by variable baln or function register()

• Your disc crashed and your codes are gone? • You’ve created too many folders like code_old

code_working, code_new2, code_final… now what?• How do you merge everybody’s code to a full-

functional system?

Page 6: Introducing Systems Analysis Design Development

Messed Up?

• Without putting your code in a function, you just wrote it down, thinking, “Hey, I’ll not use this code anywhere else! So Why do I need to put it in a function or class?”

• But, you never know…– Client may change his mind– New functionalities may appear in future– And you’re very likely to duplicate same codes.– Man is mortal. To fix buggy codes you’ll need to investigate

your whole project number of times you copy-pasted same code. • Hard to find bugs.

Page 7: Introducing Systems Analysis Design Development

Software Evolves…

• If your software is usable, it will have changes in it and have future releases.

• Clients will add new features, or users will want changes.

Page 8: Introducing Systems Analysis Design Development

After some days, you’re about to bring some changes in your code.

Page 9: Introducing Systems Analysis Design Development

And…Is that

Hebrew?

You don’t understand your

own code

Page 10: Introducing Systems Analysis Design Development

If you don’t practice standards, it’ll be very, very difficult to maintain the project later.

So What are best practices?

Page 11: Introducing Systems Analysis Design Development

Software Development Life Cycle

Page 12: Introducing Systems Analysis Design Development

Introducing SADD

• Systems…– Step 1: Analysis– Step 2: Design– Step 3: Development

• Step 4: Evolve! Back to step 1

Page 13: Introducing Systems Analysis Design Development

First Step: Systems Analysis

• Known as Requirement Analysis• Extract information from your clients on what

the software is supposed to do.• Place them on SRS Cards

• Useful to understand the total scope of application, defining priority and leads to modular design.

Page 14: Introducing Systems Analysis Design Development

Sample Requirement Analysis for some Alumni Website…

Page 15: Introducing Systems Analysis Design Development

SRS (Software Requirement Specification) Cards for Requirement Analysis

Page 16: Introducing Systems Analysis Design Development

Step 2: Design your system

• Once you’re done with analysis, design it.• The great majority of the types of errors found

in testing the code had originated in the design phase – See figure in next slide.

Page 17: Introducing Systems Analysis Design Development
Page 18: Introducing Systems Analysis Design Development

Systems Design

• Following Design Patterns– Why reinvent the wheel?

• Modular Design– Loosely coupled code– Easy to extend your program– Code less. Reuse your code

• Build Wireframes• Follow Single Responsibility Principle

Page 19: Introducing Systems Analysis Design Development

Building Wireframe

• Create Mock-up/prototype of your application before starting coding.– Can be built using GUI tools very rapidly– Client can know how your application will look

like/interact with users.– Non functional.

Page 20: Introducing Systems Analysis Design Development

Wireframe Tools

Page 21: Introducing Systems Analysis Design Development

Single Responsibility Principle

Page 22: Introducing Systems Analysis Design Development

Development: Teamwork

Page 23: Introducing Systems Analysis Design Development

Code Green. Test Units.

Page 24: Introducing Systems Analysis Design Development

Documentation

• You alone are not coding– Others will work with your code– You will work with other’s code.

• Provide Documentation

Page 25: Introducing Systems Analysis Design Development

Take help of Development Tools

• You figured out you need a change in some part, you could change it, but others’ code can break?

• You hardly understand what your friend means by variable baln or function register()

• Your disc crashed and your codes are gone? • You’ve created too many folders like code_old

code_working, code_new2, code_final… now what?

• How do you merge everybody’s code to a full-functional system?

Refractor

Distributed

Repos

Revision

Controlling

Unit Test

Page 26: Introducing Systems Analysis Design Development

Understanding Your Responsibility

Is that you?

You need to work with a

lot of people!

Page 27: Introducing Systems Analysis Design Development

Project Management Tools

• Coding is not your only responsibility.– Issues are assigned to you by your Project

Manager– Bug fixing tasks assigned to you– You fix code and re-assign it to Tester.

• To simplify all these, various Tools are available. – Using these tools guarantee standards.

Page 28: Introducing Systems Analysis Design Development

Tools: Revision Controlling

• Git is a powerful distributed version controlling system.– Stores complete history of your source code at

different stages of project life cycle.– Easy merging of everyone’s copy of work.– Distributed.

Page 29: Introducing Systems Analysis Design Development

Project Management Tools

• Project Management applications come with rich features like– Role Management (PM, Tester, Designer,

Programmer,…)– Bugs Reporting– Issue Tracking & Assigning– Gaunt Charts for schedule management– Documentation

Page 30: Introducing Systems Analysis Design Development

Tools: Gaunt Chart

Page 31: Introducing Systems Analysis Design Development

Thank You!

• Presentation prepared by– Shafiul Azam Chowdhury– Student, CSE, BUET– http://shafiul.users.sf.net

Page 32: Introducing Systems Analysis Design Development

References• http://mixergy.com/wp-content/uploads/fast-typing.jpg• http://www.confessionsofaphotoshopnerd.com/storage/Confessions%20of%20

a%20photoshop%20nerd.jpg?__SQUARESPACE_CACHEVERSION=1294205000507

• http://www.fgsd.com.au/wp-content/uploads/2011/09/Software-Policies-Processes.jpg

• http://en.wikipedia.org/wiki/Systems_development_life-cycle• http://sunset.usc.edu/csse/TECHRPTS/1975/usccse75-501/usccse75-501.pdf• http://farm6.static.flickr.com/5227/5643033953_9b542af5a1.jpg• www.jsu.edu/mcis/docs/SRSSample.doc• http://cdn.seomoz.org/images/upload/axure-wireframe.gif• http://www.re-vision.com/webwork/p27wireframes/drawing_small.jpg• http://elegantcode.com/2008/12/22/single-responsibility-principle/• http://www.emqube.com/images/side_team.jpg• http://www.bluecollarobjects.com/pub/Main/TestDrivenDevelopment/RedGren

RefactorTight.jpg• http://www.agilemodeling.com/images/generalizingSpecialistsTaylorism.jpg• http://home.snc.edu/eliotelfner/333/pictures/Gantt.gif