簡易檢索 / 詳目顯示

研究生: 林恆毅
Heng-Yi Lin
論文名稱: 針對Java Monitor的可達性測試
Reachability Testing with Java Monitor
指導教授: 黃冠寰
Hwang, Gwan-Hwan
學位類別: 碩士
Master
系所名稱: 資訊工程學系
Department of Computer Science and Information Engineering
論文出版年: 2012
畢業學年度: 100
語文別: 中文
論文頁數: 61
中文關鍵詞: 並行程式訊號機共享記憶體非決定性行為並行測試同步序列可達性測試動態效率測試監視器
英文關鍵詞: Concurrent program, Semaphore, Shared-memory, Nondeterministic behavior, Concurrent testing, SYN-sequence, Reachability testing, Dynamic effective testing, Java monitor
論文種類: 學術論文
相關次數: 點閱:93下載:3
分享至:
查詢本校圖書館目錄 查詢臺灣博碩士論文知識加值系統 勘誤回報
  • 隨著多核心電腦的快速發展,軟體也趨向多執行緒開發,然而,並行程式會造成非決定性行為,也就是說給定一組輸入,執行多次後可能會產生多個不同運行順序和結果,這產生了一個關於同步程式測試的重要議題:如何將目標程式所有可能執行順序找出來,在這篇論文中,我們提出了一個動態測試架構,可運用在Java監視器和共享記憶體上,這個動態測試架構只需要去分析在執行時蒐集到的同步序列,而不需要對語法以及語義做靜態測試,更不需要使用測試模組來找出所有可能的交錯執行順序,只要可行的同步序列是有限的,就能使用我們提出的架構來進行測試,找出並行程式所有可能的執行順序,達到測試的效果。

    Concurrent programs exhibit nondeterministic behavior in that multiple executions thereof with the same input might produce different sequences of synchronization events and different results. This is because different executions of a concurrent major issues in the testing of concurrent programs is to explore different interleavings or exhaust all the possible interleavings of the target programs. In this paper we present a framework we have developed for performing dynamic testing on monitor-based and shared-memory concurrent programs. The proposed scheme only has to analyze the synchronization sequences (SYN-sequences) that are collected during the dynamic testing of the concurrent program – static analysis of syntax and semantics of the target concurrent program is unnecessary. It also does not need to employ a model checker to explore the feasible interleavings of the execution of the concurrent program. If the SYN-sequence of the tested concurrent program is finite, our scheme can perform dynamic testing on all the feasible SYN-sequences. The implementation and experimental results obtained with real codes and some benchmark programs demonstrate the feasibility of the proposed scheme.

    第 1 章 緒論 1 1.1 並行程式測試 1 1.2 靜態測試 2 1.3 動態測試 3 1.4 可達性測試 3 1.5 Java Monitor 5 1.6 論文組織 8 第 2 章 文獻探討 9 第 3 章 測試架構 12 第 4 章 Java monitor 協定 14 4.1 Java Monitor 狀態 14 4.2 前綴重播 18 4.2.1 共享記憶體上的可達性測試 19 4.2.2 同步序列格式 21 4.2.3 同步協定-- AcquireEntry、AcquireExit和ReleaseEntry 21 4.2.4 同步協定-- WaitEntry、WaitExit、Notify和NotifyAllEntry 29 4.3 超時機制 35 第 5 章 產生可行的競爭變異 39 7.1 RW 運算轉換 39 7.2 不可行競爭變異 42 7.3 過濾競爭變異 45 7.4 完成可達性測試 49 第 6 章 實作與實驗結果 52 第 7 章 結論與未來展望 56 7.1 結論 56 7.2 展望 56 參考著作 58

    [1]Charles E. Mcdowell and David P. Helmold, "Debugging Concurrent Programs," ACM Computing Surveys, Volume 21, Issue 4, December 1989.
    [2]Anne Dinning, "A Survey of Synchronization Methods for Parallel Computers, " IEEE Computer, July 1989.
    [3]Abraham Silberschatz, Peter Baer Galvin, and Greg Gagne, "Operation System Concepts, " John Wiley & Sons, ISBN: 0471417432, 6th Edition, June 26, 2001.
    [4]Gwan-Hwan Hwang, Kuo-Chung Tai, and Ting-Lu Huang, "Reachability Testing: An Approach To Testing Concurrent Software, " International Journal of Software Engineering and Knowledge Engineering, 5, 4, pp. 493-510, December 1995.
    [5]Gwan-Hwan Hwang, "A Systematic Parallel Testing Method for Concurrent Programs, "Master Thesis, Institute of Computer Science and Information Engineer, National Chiao-Tung University, Taiwan, 1993.
    [6]Roger S. Pressman, "Software Engineering (A practitioner’s approach), " 5th Edition, 2000, Mc Graw-Hill Education, ISBN 978-0071181822.
    [7]K. C. Tai, "Testing of Concurrent Software, " Proceeding of the 13th annual International Computer Software and Applications Conference, pp. 62-64, 1989.
    [8]S. D. Stoller, "Testing Concurrent Java Programs Using Randomized Scheduling," Proceedings of the 2nd Workshop on Runtime Verification, Amsterdam, 2002.
    [9]Edelstein O., Farchi E., Nir Y., Ratsaby G., and Ur S.,"Multithreaded Java Program Test Generation," IBM Systems Journal, Volume 41, Issue 1, pp. 111-125, 2002.
    [10]D. Helmbold and D. Luckham, "Debugging Ada Tasking Programs, " IEEE Software, Volume 2, Number2, pp. 66-74, 1985.
    [11]Y. Ben-Asher, E. Farchi, and Y. Eytani, "Heuristics for Fingin Concurrent Bugs, " Proceeding of the International Parallel and Distributed Processing Symposium (IPDPS 2003), April, 2003.
    [12]Gwan-Hwan Hwang, Sheng-Jen Chang, and Huey-Der Chu, " Technology for Testing Nondeterministic Client/Server Database Applications, " IEEE Transaction on software Engineering, Volume 30, Number 1, pp. 59-77, January, 2004.
    [13]K. Sen, "Effective Random Testing of Concurrent Programs, " Proceedings of 22nd IEEE/ACM International Conference on Automated Software Engineering (ASE '07), pp. 323-332, 2007.
    [14]P. Joshi, M. Naik, C.S. Park, and K. Sen, "An Extensible Active Testing Framework for Concurrent Programs," Proceedings 21st International Conference on Computer Aided Verification (CAV '09), 2009.
    [15]"ConTest — A Tool for Testing Multi-threaded Java Applications, " http://www.haifa.ibm.com/projects/verification/contest/ .
    [16]Orit Edelstein, Eitan Farchi, Evgeny Golden, Yarden Nir, Gil Ratsaby, and Shmuel Ur, "ConTest — A User's Perspective," The 5th International Conference on Achieving Quality in Software, Italy, March 13, 2002.
    [17]T. Li, C. S. Ellis, A. R. Lebeck, and D. J. Sorin, "Pulse: A Dynamic Deadlock Detection Mechanism Using Speculative Execution, " Proc. USENIX Annual Technical Conf., pp. 31-44, 2005.
    [18]Microsoft, "CHESS: Find and Reproduce Heisenbugs in Concurrent Program, " http://research.microsoft.com/en-us/projects/chess/, 2010.
    [19]M. Musuvathi, S. Qadeer, and T. Ball, "CHESS: A Systematic Testing Tool for Concurrent Software, "Microsoft Research Technical Report MSR-TR-2007-149, 2007.
    [20]M. Musuvathi and S. Qadeer, "Fair stateless Model Checking," ACM Conference on Programming Language Design and Implementation (PLDI), 2008.
    [21]Felipe S. Sarmanhol, Paulo S. L. Souzal, Simone R. S. Souzal, and Adenilso S. Simaol, "Structual Testing for Semaphore-Based Multithread Programs, " ICCS 2008, LNCS 5101, pp. 337-346, 2008.
    [22]Rahul Agarwal and Scott D. Stoller, "Run-time detection of potential deadlocks for programs with locks, semaphores, and condition variable, " Proc. 2006 workshop on Parallel and distributed systems: testing and debugging, pp. 51-60, 2006.
    [23]A. Williams, W. Thies, and M. D. Ernst, "Static deadlock detection for Java libraries, " ECOOP 2005, LNCS 3586, pp. 602-629, 2005.
    [24]Kuo-Chung Tai, "Reachability Testing of Asynchronous Message-passing Programs, " Proceeding of the second International Workshop on Software Engineering for Parallel and Distributed Systems, 1997.
    [25]Richard H. Carver and Yu Lei, "A General Model for Reachability Testing of Concurrent Programs, "ICFEM 2004, LNCS 3308, pp. 76-98, 2004.
    [26]Yu Lei and Richard H. Carver, "Reachability Testing of Concurrent Programs, " IEEE Transactions on Software Engineering, vol. 32, no. 6, pp. 382-403, June 2006.
    [27]Che-Sheng Lin and Gwang-Hwan Hwang, "State-cover Testing for Nondeterministic Concurrent Programs with an Infinite number of Synchronization Sequences," submitted to IEEE Transaction on Software Engineering for publication.
    [28]Che-Sheng Lin and Gwan-Hwan Hwang, "Dynamic Effective Testing: An Approach to Testing Concurrent Programs," Technical Report, National Taiwan Normal University, 2010.
    [29]Yu Lei, Carver R., Kung D., Gupta V., Hernandez M., "A State Exploration-Based Approach to Testing Java Monitors," International Symposium on Software Reliability Engineering (ISSRE '06), pp. 256-265, Nov. 2006.
    [30]Verification and Validation Laboratory, Computer Science Department, Brigham Young University, "Concurrency Tool Comparison," https://facwiki.cs.byu.edu/vv-lab/index.php/Concurrency_Tool_Comparison.
    [31]Allen B. Downey, "The little book of Semaphores," 2008.

    下載圖示
    QR CODE