ProMiner: Bi-Directional Consistency Checking Framework Based on System Properties
Author:
Affiliation:

Fund Project:

Natural Science Foundation of Shanghai (13ZR1413000); National Science and Technology Major Project (2014ZX01038-101-001); National Natural Science Foundation of China (61502170, 91118008); NSFC Projects of International Cooperation and Exchanges (61361136002); Science Fund for Creative Research Groups of the National Natural ScienceFoundation of China (61321064)

  • Article
  • | |
  • Metrics
  • |
  • Reference [29]
  • |
  • Related
  • |
  • Cited by
  • | |
  • Comments
    Abstract:

    Model-Driven development is currently a highly regarded software development paradigm among software developers and researchers, and model-based testing techniques are usually applied during the development to ensure the quality of software systems. With the growing size and complexity of software systems, maintaining the consistency between software models and their implementation become more and more challenging. While traditional model-based testing focuses on ensuring the software implementation comply with its designed model, this work addresses particularly the situation where the implementation is modified while software models are left outdated due to workarounds or other unexpected changes during development. The paper presents an automated consistency checking framework, ProMiner, which extends traditional model-based testing with mining software properties that represent the identified inconsistencies as linear temporal logic (LTL). Experiments show that this extended consistency checking technique effectively helps software designer to narrow down the specific locations of software models that need to be updated with respects to its running implementation.

    Reference
    [1] Duan YC, Gu YQ. A multi-dimensional separation of concerns approach for model driven process framework modeling. Ruan Jian Xue Bao/Journal of Software, 2006,17(8):1707-1716(in Chinese with English abstract). http://www.jos.org.cn/1000-9825/17/1707.htm[doi:10.1360/jos171707]
    [2] Schmidt DC. Guest editor's introduction:Model-Driven engineering. Computer, 2006,39(2):25-31.[doi:10.1109/MC.2006.58]
    [3] Dias Neto AC, Subramanyan R, Vieira M, Travassos GH. A survey on model-based testing approaches:A systematic review. In:Proc. of the 1st ACM Int'l Workshop on Empirical Assessment of Software Engineering Languages and Technologies:Held in Conjunction with the 22nd IEEE/ACM Int'l Conf. on Automated Software Engineering (ASE 2007). ACM Press, 2007.31-36.[doi:10.1145/1353673.1353681]
    [4] Liu H, Ma ZY, Shao WZ. Progress of research on metamodeling. Ruan Jian Xue Bao/Journal of Software, 2008,19(6):1317-1327(in Chinese with English abstract). http://www.jos.org.cn/1000-9825/19/1317.htm[doi:10.3724/SP.J.1001.2008.01317]
    [5] Wang J, Li XD. Preface to special issue on formal methods and tools. Ruan Jian Xue Bao/Journal of Software, 2011,22(6):1121-1122(in Chinese with English abstract). http://www.jos.org.cn/1000-9825/4036.htm[doi:10.3724/SP.J.1001.2011.04036]
    [6] Huth M, Ryan M. Logic in Computer Science:Modelling and Reasoning About Systems. Cambridge:Cambridge University Press, 2004.175-186.
    [7] Tao QM, Zhao C, Guo L. Proving soundness of program transformations in optimizing compilation based on temporal logic. Ruan Jian Xue Bao/Journal of Software, 2009,20(8):2074-2086(in Chinese with English abstract). http://www.jos.org.cn/1000-9825/3378.htm[doi:10.3724/SP.J.1001.2009.03378]
    [8] Clarke EM, Grumberg O, Peled D. Model Checking. Cambrige:The MIT Press, 1999.35-50.
    [9] Lin HM, Zhang WH. Model checking:Theories, techniques and applications. Acta Electronica Sinica, 2002,30(Z1):1907-1912(in Chinese with English abstract).
    [10] Abrial JR. Modeling in Event-B:System and Software Engineering. Cambrige:Cambridge University Press, 2010.176-188.
    [11] Abrial JR, Butler M, Hallerstede S, Hoang TS, Mehta F, Voisin L. Rodin:An open toolset for modelling and reasoning in Event-B. Int'l Journal on Software Tools for Technology Transfer (STTT), 2010,12(6):447-466.[doi:10.1007/s10009-010-0145-y]
    [12] Dinca I, Ipate F, Mierla L, Stefanescu A. Learn and test for Event-B-A Rodin plugin. In:Proc. of the Abstract State Machines, Alloy, B, VDM, and Z. Berlin, Heidelberg:Springer-Verlag, 2012.361-364.[doi:10.1007/978-3-642-30885-7_32]
    [13] Leuschel M, Butler M. ProB:A model checker for B. In:Proc. of the FME 2003:Formal Methods. Berlin, Heidelberg:Springer-Verlag, 2003.855-874.[doi:10.1007/978-3-540-45236-2_46]
    [14] Zhang Y, Guo J, Zhu XR, Wang WJ, Zhu JY, Tang JH, Chen JN. Modeling and development of multi-application smart cards based on Event-B. Computer Engineering and Science, 2014,36(10):1943-1951(in Chinese with English abstract).
    [15] Zhang Y, Guo J, Zhu XR. Application of model-based development method in multi-application smart cards. Netinfo Security, 2013,(156):75-79(in Chinese with English abstract).
    [16] Zhou Y, Zheng GL, Li XD. An operational semantics for UML state machines in model checking context. Acta Electronica Sinica, 2003,31(Z1):2091-2095(in Chinese with English abstract).
    [17] Lo D, Ramalingam G, Ranganath VP, Vaswani K. Mining quantified temporal rules:Formalism, algorithms, and evaluation. In:Proc. of the 16th Working Conf. on Reverse Engineering (WCRE 2009). IEEE, 2009.62-71.[doi:10.1109/WCRE.2009.42]
    [18] Ernst MD, Perkins JH, Guo PJ, McCamant S, Pacheco C, Tschantz MS, Xiao C. The Daikon system for dynamic detection of likely invariants. Science of Computer Programming, 2007,69(1):35-45.
    [19] Murray G, Barton ES. Scalable and systematic detection of buggy inconsistencies in source code. ACM Sigplan Notices, 2010, 45(10):175-190.[doi:10.1145/1869459.1869475]
    [20] Gabel M, Su Z. Testing mined specifications. In:Proc. of the ACM SIGSOFT 20th Int'l Symp. on the Foundations of Software Engineering. ACM Press, 2012.4.[doi:10.1145/2393596.2393598]
    附中文参考文献:
    [1] 段玉聪,顾毓清.多维关注分离的模型驱动过程框架设计方法.软件学报,2006,17(8):1707-1716. http://www.jos.org.cn/1000-9825/17/1707.htm[doi:10.1360/jos171707]
    [4] 刘辉,麻志毅,邵维忠.元建模技术研究进展.软件学报,2008,19(6):1317-1327. http://www.jos.org.cn/1000-9825/19/1317.htm[doi:10.3724/SP.J.1001.2008.01317]
    [5] 王戟,李宣东.形式化方法与工具专刊前言.软件学报,2011,22(6):1121-1122. http://www.jos.org.cn/1000-9825/4036.htm[doi:10.3724/SP.J.1001.2011.04036]
    [7] 陶秋铭,赵琛,郭亮.基于时序逻辑证明编译优化程序变换的保义性.软件学报,2009,20(8):2074-2086. http://www.jos.org.cn/1000-9825/3378.htm[doi:10.3724/SP.J.1001.2009.03378]
    [9] 林惠民,张文辉.模型检测:理论、方法与应用.电子学报,2002,30(Z1):1907-1912.
    [14] 章玥,郭建,朱晓冉,王文君,朱晶洋,汤家华,陈峻念.基于Event-B方法的多应用智能卡的建模与开发.计算机工程与科学,2014, 36(10):1943-1951.
    [15] 章玥,郭建,朱晓冉.基于模型的开发方法在多应用智能卡中的应用.信息网络安全,2013,(156):75-79.
    [16] 周颖,郑国梁,李宣东.面向模型检验的UML状态机语义.电子学报,2003,31(Z1):2091-2095.
    Related
    Cited by
    Comments
    Comments
    分享到微博
    Submit
Get Citation

葛徐骏,王玲,徐立华,郭建,朱惠彪. ProMiner:系统性质驱动的双向一致性检验框架.软件学报,2016,27(7):1757-1771

Copy
Share
Article Metrics
  • Abstract:
  • PDF:
  • HTML:
  • Cited by:
History
  • Received:August 14,2014
  • Revised:January 27,2015
  • Online: July 07,2016
You are the first2032471Visitors
Copyright: Institute of Software, Chinese Academy of Sciences Beijing ICP No. 05046678-4
Address:4# South Fourth Street, Zhong Guan Cun, Beijing 100190,Postal Code:100190
Phone:010-62562563 Fax:010-62562533 Email:jos@iscas.ac.cn
Technical Support:Beijing Qinyun Technology Development Co., Ltd.

Beijing Public Network Security No. 11040202500063