dc.contributor | Silva, Rodolfo Adamshuk | |
dc.contributor | Silva, Rodolfo Adamshuk | |
dc.contributor | Souza, Francisco Carlos Monteiro | |
dc.contributor | Oliveira, Rafael Alves Paes de | |
dc.creator | Bordignon, Matheus Deon | |
dc.date.accessioned | 2020-11-13T11:57:07Z | |
dc.date.accessioned | 2022-12-06T14:54:29Z | |
dc.date.available | 2020-11-13T11:57:07Z | |
dc.date.available | 2022-12-06T14:54:29Z | |
dc.date.created | 2020-11-13T11:57:07Z | |
dc.date.issued | 2019-11-26 | |
dc.identifier | BORDIGNON, Matheus Deon. Teste de mutação para programas concorrentes em elixir. 2019. Trabalho de Conclusão de Curso (Bacharelado em Engenharia de Software) - Universidade Tecnológica Federal do Paraná, Dois Vizinhos, 2019. | |
dc.identifier | http://repositorio.utfpr.edu.br/jspui/handle/1/10771 | |
dc.identifier.uri | https://repositorioslatinoamericanos.uchile.cl/handle/2250/5257829 | |
dc.description.abstract | The processing capacity of computers has been insufficient and encourages the use of concurrent programming for the development of applications that reduce computational time. Elixir is a language that supports the development of concurrent and distributed applications in a dynamic and modern way. The use of concurrent programming differs from sequential programming, adding features such as communication, synchronization, and non-determinism to programs. Testing activities seek to guarantee the quality and correctness of the programs and they become more complex due to these characteristics presents in concurrent programs. Mutation testing is a test criterion based on mistakes made by programmers during software development and is highly effective in revealing defects. The aim of this work is the definition of mutation operators for concurrent functions in Elixir. For this, a benchmark of concurrent programs in Elixir was built and validated to aid in software testing activity. Using the benchmark, the fault taxonomy in Elixir was defined, exploiting the faults produced by the concurrent functions of the Kernel and the Task module. Considering the faults of the taxonomy and exploiting typical programmer mistakes during development, a set of mutation operators was defined to exploit concurrents aspects. Also, an experiment was proposed to evaluate some quality characteristics of the defined mutation operators and the results showed that the ReplSpawn mutation operator generated the largest number of mutants, while the DelReceive operator demonstred more completeness in the scope of fault taxonomy. The inclusion rate of the deletion mutation operators in relation to the DelSpawn and DelTaskStart operators was also calculated. | |
dc.publisher | Universidade Tecnológica Federal do Paraná | |
dc.publisher | Dois Vizinhos | |
dc.publisher | Brasil | |
dc.publisher | Engenharia de Software | |
dc.publisher | UTFPR | |
dc.rights | openAccess | |
dc.subject | Linguagens de programação funcional | |
dc.subject | Software - Desenvolvimento | |
dc.subject | Engenharia de software | |
dc.subject | Functional programming languages | |
dc.subject | Computer software - Development | |
dc.subject | Software engineering | |
dc.title | Teste de mutação para programas concorrentes em elixir | |
dc.type | bachelorThesis | |