Descripción del proyecto
«Software» automatizado que prueba sistemas informáticos como lo haría una persona
Incluso los programas informáticos más sencillos pueden presentar errores de ejecución cuando se reciben entradas inesperadas. Las pruebas de «software» antes de su lanzamiento dependen en gran medida de que las personas prueben una lista prácticamente interminable de acciones que podrían provocar fallos en el sistema. Automatizar solo una parte de este proceso mejoraría notablemente la eficiencia y eficacia de las actividades de verificación y reduciría de forma sustancial los costes de desarrollo. El equipo del proyecto AST, financiado por el Consejo Europeo de Investigación, desarrollará una herramienta precomercial para generar de forma eficiente y automática casos de prueba de sistemas semánticamente relevantes. Explotará técnicas de aprendizaje por refuerzo para aprender de forma incremental y automática las acciones de prueba más útiles que pueden realizarse en una interfaz gráfica de usuario.
Objetivo
Verifying the correctness of software systems requires extensive and expensive testing sessions. While there are tools and methodologies to efficiently address unit and integration testing, system testing is still largely the result of manual effort.
Testing software applications at the system level requires executing the applications through their interfaces to verify the correctness of their functionalities and stimulate all their layers and components. Automating just part of this process can dramatically improve the effectiveness of verification activities and significantly reduce development costs, relevantly alleviating developers from their verification effort.
This project addresses the development of a pre-commercial tool that has the unique capability of efficiently and automatically generating semantically-relevant system test cases equipped with functional oracles. This capability derives from the AUGUSTO technique, which is an outcome of the Learn ERC project. The idea behind Augusto is to exploit the common-sense knowledge, that is, the background knowledge that every computer user has and that normally lets her/him use software applications without the need of accessing any documentation or manual. Once this knowledge is represented abstractly and then embedded in AUGUSTO, the technique can automatically adapt its definition to the software under test every time a program is tested.
This development work will be performed jointly with A company that produces and markets testing tools.
Ámbito científico
- natural sciencescomputer and information sciencessoftwaresoftware applicationssystem software
- natural sciencescomputer and information sciencesknowledge engineering
- natural sciencescomputer and information sciencessoftwaresoftware development
- natural sciencescomputer and information sciencesartificial intelligencecomputational intelligence
Programa(s)
Régimen de financiación
ERC-POC - Proof of Concept GrantInstitución de acogida
20126 MILANO
Italia