Effective Software Mutation-Test Using Program Instructions Classification
dc.authorid | Arasteh, Bahman/0000-0001-5202-6315 | |
dc.authorwosid | Arasteh, Bahman/AAN-9555-2021 | |
dc.contributor.author | Asghari, Zeinab | |
dc.contributor.author | Arasteh, Bahman | |
dc.contributor.author | Koochari, Abbas | |
dc.date.accessioned | 2024-05-19T14:46:45Z | |
dc.date.available | 2024-05-19T14:46:45Z | |
dc.date.issued | 2023 | |
dc.department | İstinye Üniversitesi | en_US |
dc.description.abstract | The quantity of bugs that a software test-data finds determines its effectiveness. A useful technique for assessing the efficacy of a test set is mutation testing. The primary issues with the mutation test are cost and time requirements. Close to 40% of the injected bugs in the mutation test are effect-less (equivalent). Reducing the number of generated total mutants by decreasing equivalent mutants and reducing the execution time of the mutation test are the main objectives of this study. An error-propagation aware mutation test approach has been suggested in this research. Three steps make up the process. To find a collection of instruction-level characteristics effective on the error propagation rate, the data and instructions of the input program were evaluated in the first step. Utilizing supervised machine learning techniques, an instruction classifier was developed using the prepared dataset in the second step. After classifying the program instructions automatically by the created classifier, the mutation test is performed only on the identified error-propagating instructions; the identified non-error-propagating instructions are avoided to mutate in the proposed mutation testing. The conducted experiments on the set of standard benchmark programs indicate that the proposed method causes about 19% reduction in the number of generated mutants. Furthermore, the proposed method causes a 32.24% reduction in the live mutants. It should be noted that the proposed method eliminated only the affectless mutants. The key technical benefit of the suggested solution is that mutation of the instructions that don't propagate errors is avoided. These findings can lead to a performance improvement in the existing mutation-test methods and tools. | en_US |
dc.identifier.doi | 10.1007/s10836-023-06089-0 | |
dc.identifier.endpage | 657 | en_US |
dc.identifier.issn | 0923-8174 | |
dc.identifier.issn | 1573-0727 | |
dc.identifier.issue | 5-6 | en_US |
dc.identifier.scopus | 2-s2.0-85181874716 | en_US |
dc.identifier.scopusquality | Q3 | en_US |
dc.identifier.startpage | 631 | en_US |
dc.identifier.uri | https://doi.org10.1007/s10836-023-06089-0 | |
dc.identifier.uri | https://hdl.handle.net/20.500.12713/5586 | |
dc.identifier.volume | 39 | en_US |
dc.identifier.wos | WOS:001138239100001 | en_US |
dc.identifier.wosquality | N/A | en_US |
dc.indekslendigikaynak | Web of Science | en_US |
dc.indekslendigikaynak | Scopus | en_US |
dc.language.iso | en | en_US |
dc.publisher | Springer | en_US |
dc.relation.ispartof | Journal of Electronic Testing-Theory and Applications | en_US |
dc.relation.publicationcategory | Makale - Uluslararası Hakemli Dergi - Kurum Öğretim Elemanı | en_US |
dc.rights | info:eu-repo/semantics/closedAccess | en_US |
dc.snmz | 20240519_ka | en_US |
dc.subject | Software Test | en_US |
dc.subject | Equivalent Mutant | en_US |
dc.subject | Error Propagation | en_US |
dc.subject | Machine Learning | en_US |
dc.subject | Instruction Classification | en_US |
dc.title | Effective Software Mutation-Test Using Program Instructions Classification | en_US |
dc.type | Article | en_US |