/software-engineering

This course is designed to give students an introduction to an engineering approach in the development of high-quality software systems. It will discuss the important software engineering concepts in the various types of the common software process models.

Primary LanguageHTML

Stars Badge Forks Badge Pull Requests Badge Issues Badge GitHub contributors

Don't forget to hit the ⭐ if you like this repo.

Software Engineering (WBL)

Course Synopsis

This course is designed to give students an introduction to an engineering approach in the development of high-quality software systems. It will discuss the important software engineering concepts in the various types of the common software process models. The students will also learn the concepts and techniques used in each software development phase including requirements engineering, software design and software testing. This course will also expose the students to utilizing object-oriented method (e.g., UML) and tools in analyzing and designing the software. At the end of this course, students are expected to be able to appreciate most of the common software engineering concepts and techniques as well as producing various software artifacts and deliverables.

Course Learning Outcomes

  1. Apply the fundamental of software engineering, software process, requirements engineering to solve software engineering case studies.
  2. Build suitable software architecture, object-oriented design model and develop test cases in software engineering case studies.
  3. Construct software requirements model, software architecture, object-oriented design model and test cases with state-of-the-art methods and tools for a real-world software engineering problem.
  4. Ability to establish good rapport, interact with others, work effectively in a team and comprehend the interchangeable role of leaders and followers with team members.

🔥 Important things

  1. Lecture Notes
  2. Task 1: Additional Notes
  3. Lab exercise
  4. Software Engineering Project
  5. Guideline for Software Engineering Proposal
  6. Tender dan sebut harga

Weekly Schedule

Week Module Description 01 02
1 1: Introduction to Software Engineering Software definition, software engineering as a layered technology, types of software, inherent difficulties in software engineering, SE quality focus, Documentation Standard.
2 2: Software Process Model Plan Driven or Agile Process Model, general software process model waterfall, incremental, reuse oriented, software process model which cope with change spiral model and Rational Unified Process
3 3: Agile Software Development Agile methods, Agile development techniques, Agile project management, scaling Agile methods
4 4: Requirements Engineering Types of requirements, functional and non-functional requirements, requirements specification, requirements engineering processes
5 5: Requirements Analysis and modelling ME Use case modelling and specification, domain modelling, activity diagram, sequence diagram, state chart/state machine diagram
6 Industry Day I: Project requirement sharing.
7 MID-SEMESTER BREAK
8 Software Engineering project – Requirements analysis and models. Produce requirements document* that includes all the required analysis models
9 6: Architectural Design Architectural design and detailed design, Architectural design decision, architectural view, component diagram in relation to architectural view, architectural pattern: Model-View-Controller (MVC), layered, repository, client server and pipe filter
10 7: Object-Oriented Detailed Design Relationships among analysis, design and implementation, object-oriented design using UML, object-oriented design principles, elaborating UML diagrams from analysis.
11 Software Engineering project – Design model. Produce design document* that includes all the required design models
12 8: Software verification, validation and testing Introduction to verification and validation, verification and validation planning, software inspections. System testing, Component testing, Test case design, Test Case Design using Black-box and white box
13 Software Engineering project – Test case design. Produce testing document* that includes all the required test cases
14 TENTATIVE - ALTERNATIVE ASSESSMENT (TBC)
15 Industry Day II: Project demonstration and hand over.

Student Information

Notes

Introduction to Software Engineering

Markdown Tools

Five great tools for creating diagrams and flowcharts

  1. Mermaid.js: Mermaid.js is a popular JavaScript library for creating diagrams and flowcharts using Markdown syntax. It's open source, easy to use, and supports a wide range of diagram types.

  2. PlantUML: PlantUML is a tool for creating UML diagrams using a simple textual syntax. It supports a variety of diagram types, including class diagrams, use case diagrams, sequence diagrams, and more.

  3. Graphviz: Graphviz is a powerful tool for creating graphs and diagrams using a simple textual syntax. It supports a wide range of graph types, including directed and undirected graphs, flowcharts, and more.

  4. Diagrams.net: Diagrams.net (formerly known as Draw.io) is a web-based diagramming tool that supports a variety of diagram types, including flowcharts, network diagrams, and more. It has a simple interface and supports Markdown syntax for creating diagrams.

  5. yEd Graph Editor: yEd Graph Editor is a desktop application for creating diagrams and flowcharts. It supports a wide range of diagram types and has a simple interface that makes it easy to create and edit diagrams. It also supports Markdown syntax for creating diagrams.

Five tools that can help you create system architecture diagrams

  1. Structurizr: Structurizr is a powerful tool for creating system architecture diagrams using code. It supports a range of diagram types, including context diagrams, container diagrams, and component diagrams. You can create and maintain diagrams using a simple DSL written in Markdown.

  2. C4-PlantUML: C4-PlantUML is an extension to PlantUML that provides support for creating system architecture diagrams. It uses a simple textual syntax to describe the system architecture, and supports a range of diagram types including context diagrams, container diagrams, and component diagrams.

  3. Nomnoml: Nomnoml is a tool for creating UML diagrams using a simple textual syntax. It's lightweight and easy to use, and supports a range of diagram types, including class diagrams, sequence diagrams, and more. You can use Nomnoml to create system architecture diagrams using Markdown syntax.

  4. Mermaid.js: Mermaid.js, which was mentioned earlier as a tool for creating diagrams and flowcharts using Markdown syntax, also supports system architecture diagrams. It supports a range of diagram types, including sequence diagrams, flowcharts, and more.

  5. Vega-Lite: Vega-Lite is a declarative visualization tool that can be used to create a range of visualizations, including system architecture diagrams. It supports a simple JSON-based syntax, which can be generated using a Markdown document, and can be used to create interactive and static diagrams.

Contribution 🛠️

Please create an Issue for any improvements, suggestions or errors in the content.

You can also contact me using Linkedin for any other queries or feedback.