Proceedings of the Institute for System Programming of the RAS
RUS  ENG    JOURNALS   PEOPLE   ORGANISATIONS   CONFERENCES   SEMINARS   VIDEO LIBRARY   PACKAGE AMSBIB  
General information
Latest issue
Archive

Search papers
Search references

RSS
Latest issue
Current issues
Archive issues
What is RSS



Proceedings of ISP RAS:
Year:
Volume:
Issue:
Page:
Find






Personal entry:
Login:
Password:
Save password
Enter
Forgotten password?
Register


Proceedings of the Institute for System Programming of the RAS, 2015, Volume 27, Issue 5, Pages 157–174
DOI: https://doi.org/10.15514/ISPRAS-2015-27(5)-9
(Mi tisp177)
 

This article is cited in 1 scientific paper (total in 1 paper)

Using fault injection for testing Linux kernel components

A. Tsyvareva, A. Khoroshilovabcd

a Institute for System Programming of the RAS
b Moscow Institute of Physics and Technology (State University)
c National Research University Higher School of Economics (HSE)
d Lomonosov Moscow State University
Full-text PDF (264 kB) Citations (1)
References:
Abstract: The paper considers methods of using fault injection for testing components of Linux kernel. The main goal of the methods is to check how the kernel behaves in abnormal situations such as lack of resources and hardware faults. Such situations happens quite rarely and unpredictably, that makes very difficult to detect and to localize bugs in the code responsible for their handling. The most widely-used approach to find the bugs is random fault injection during execution of normal tests. Random fault injection works much better than absence of abnormal testing at all, but it has a number of drawbacks. Its random nature does not allow to reproduce test scenarios and it does not allow to estimate absence of bugs even if all tests are passed.
The paper presents a method of systematic fault injection for robustness testing that also enables reproducibility of test scenarios out of box. The basic idea of the method is to detect all execution points where a fault can happen, to filter out the points on the base of some equivalence relation and to execute tests bringing code into the chosen execution points with injecting faults at that points.Applicability and efficiency of the approach depends on the equivalence relation. The equivalence relation can be defined using manual markup of important segments of tests or it can be defined completely automatically on the base of a set of stack traces describing a fault injection.Experimental data were collected using test suites for Linux kernel file system implementations augmented with random and systematic fault injection.The experiments demonstrate the efficiency of systematic approach and acknowledge benefits coming from its deterministic nature.
Keywords: Linux, Linux kernel, file system, driver, testing, fault simulation.
Bibliographic databases:
Document Type: Article
Language: Russian
Citation: A. Tsyvarev, A. Khoroshilov, “Using fault injection for testing Linux kernel components”, Proceedings of ISP RAS, 27:5 (2015), 157–174
Citation in format AMSBIB
\Bibitem{TsyKho15}
\by A.~Tsyvarev, A.~Khoroshilov
\paper Using fault injection for testing Linux kernel components
\jour Proceedings of ISP RAS
\yr 2015
\vol 27
\issue 5
\pages 157--174
\mathnet{http://mi.mathnet.ru/tisp177}
\crossref{https://doi.org/10.15514/ISPRAS-2015-27(5)-9}
\elib{https://elibrary.ru/item.asp?id=25141699}
Linking options:
  • https://www.mathnet.ru/eng/tisp177
  • https://www.mathnet.ru/eng/tisp/v27/i5/p157
  • This publication is cited in the following 1 articles:
    Citing articles in Google Scholar: Russian citations, English citations
    Related articles in Google Scholar: Russian articles, English articles
    Proceedings of the Institute for System Programming of the RAS
    Statistics & downloads:
    Abstract page:222
    Full-text PDF :63
    References:31
     
      Contact us:
     Terms of Use  Registration to the website  Logotypes © Steklov Mathematical Institute RAS, 2024