Qualidade do Software

Objetivos

Saber:
- Componentes de um sistema de gestão da qualidade (SGQ)
- Modelos de qualidade de software e sua avaliação
- Verificação e validação
- Princípios, objectivos e conceitos fundamentais da reengenharia de software
- Software legado
- Técnicas e ferramentas de engenharia reversa
- Reengenharia e refabricação de programas

Saber fazer:
- Reificar um SGQ para projectos de desenvolvimento de software
- Construir um modelo de qualidade de software
- Selecionar e utilizar técnicas de verificação e validação adequadas
- Avaliação crítica do grau de cobertura atingido com as técnicas de verificação e validação
- Analisar sistemas existentes de dimensão não trivial
- Obtenção/extracção de conceitos de alto nível de sistemas legados
- Elaboração de diagnósticos úteis para a reengenharia
- Dominar técnicas de reengenharia de software

Soft skills:
- Trabalho em equipa
- Defesa pública de pontos de vista

Caracterização geral

Código

11170

Créditos

6.0

Professor responsável

Miguel Carlos Pacheco Afonso Goulão, Miguel Jorge Tavares Pessoa Monteiro

Horas

Semanais - 4

Totais - 52

Idioma de ensino

Português

Pré-requisitos

Engenharia de Software, Métodos de Desenvolvimento de Software

Bibliografia

Chikofsky et al. Reverse Engineering and Design Recovery: a Taxonomy. IEEE Soft. 7(1),1990.

Lanza M.; Marinescu R. Object-Oriented Metrics in Practice. Springer-Verlag 2006.

Fowler M. Refactoring: Improving the Design of Existing Code. Addison-Wesley, 1999. 

Mens, et al.: Guest Editors'''''''''''''''' Introduction: Software Evolution. IEEE Software 27(4), 2010.

Gamma, Helm, Johnson, Vlissides. "Design Patterns Elements of reusable object-oriented software". Addison Wesley, 1995.

Myers, et al.: The Art of Software Testing, 3rd ed., 2011.

Maurício Aniche et al. “Software Testing: From Theory to Practice”, GitBook, 2021.

ISO/IEC 25023:2016

ISO/IEC 25010:2011

Método de ensino

As aulas teóricas consistem na exposição de matéria, ilustrada com exemplos de aplicação, e suportada por diapositivos e pela utilização do ambiente de desenvolvimento no computador do docente.

Nas aulas de laboratório, os alunos resolvem exercícios que constituem exemplos concretos de aplicação dos conceitos dados nas anteriores aulas teóricas.

Os alunos podem esclarecer dúvidas durante as aulas ou nos horários de atendimento.

Sempre que existam alunos que não falem Português, as aulas serão leccionadas em Inglês. Os materiais são, também, em inglês.

Método de avaliação

Componentes da Avaliação
A avaliação inclui uma componente teórica e uma componente prática.

Componente de Projecto e Frequência
A componente prática consiste em 2 trabalhos práticos e vale 40% da nota final.
Os dois Trabalhos Práticos (P1 e P2) são realizados por grupos de 2 alunos e valem 20% da nota final cada um.

Para obter frequência, um aluno tem de obter uma média ponderada das notas dos trabalhos >= 9.5 valores.

Componente teórica

A componente teórica é composta por dois testes individuais, realizados presencialmente, valendo 60% da nota final.

É permitida aos alunos trazerem consigo uma folha de consulta (duas páginas) manuscrita, que devem entregar junto com a prova.

A nota da componente teórica é a média ponderada das notas dos testes ou a nota de Exame (Ex). Para obter aprovação, é necessário obter uma média ponderada da nota dos testes (ou do exame) >= 9.5 valores e ter frequência válida.

Nota Final

Quando a Unidade Curricular é realizada por testes, o cálculo da nota final é dado por:
NF = T1 * 0.30 + T2 * 0.30 + P1 * 0.20 + P2 * 0.20

Quando a Unidade Curricular é realizada por exame, o cálculo da nota final é dado por:
NF = Ex *0.60 + P1 * 0.20 + P2 * 0.20

Para obter aprovação tem de se ter frequência e obter uma nota de avaliação teórica >= 9.5.

Caso a nota de avaliação teórica seja < 9.5, a nota final a lançar no CLIP é a nota da avaliação teórica.

Frequências do ano anterior
As frequências obtidas no ano anterior (2022/23) mantém-se válidas, bem como a respectiva nota da componente prática. Porém, para efeitos do cálculo da nota final o peso da componente prática a ser usado é o desta edição da disciplina: 40%.

Melhoria de nota em exame
Os alunos que em exame queiram melhorar a nota ponderada dos dois testes devem apresentar-se a exame. Caso a nota obtida em exame seja superior à nota ponderada dos testes, esta substitui a nota ponderada dos testes para efeitos do cálculo da nota final.

Conteúdo

1. Introdução à Qualidade de Software

2. Modelos de Qualidade de Software
2.1 Modelos de Qualidade do Processo
2.2 Modelos de Qualidade do Produto

3. Evolução de Software
3.1 Engenharia reversa de sistemas de software
3.2 Métricas de software
3.3 Visualização de software

4. Reengenharia de sistemas de software
4.1 Fundamentos de reengenharia
4.2 Refabricação

5. Desenho e Reutilização de Software
5.1 Desarmonias de concepção
5.2 Padrões de concepção

6. Verificação e Validação de Software

Cursos

Cursos onde a unidade curricular é leccionada: