app_test.py 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. #!/usr/bin/env python
  2. import re
  3. from test_panic_util.test_panic_util import panic_test, get_dut, run_all
  4. @panic_test()
  5. def test_panic_task_wdt(env, extra_data):
  6. with get_dut(env, "panic", "test_task_wdt", qemu_wdt_enable=True) as dut:
  7. dut.expect("Task watchdog got triggered. The following tasks did not reset the watchdog in time:")
  8. dut.expect("CPU 0: main")
  9. dut.expect(re.compile(r"abort\(\) was called at PC [0-9xa-f]+ on core 0"))
  10. dut.expect_none("register dump:")
  11. dut.expect_backtrace()
  12. dut.expect_elf_sha256()
  13. dut.expect_none("CORRUPTED", "Guru Meditation")
  14. dut.expect("Rebooting...")
  15. @panic_test()
  16. def test_panic_int_wdt(env, extra_data):
  17. with get_dut(env, "panic", "test_int_wdt", qemu_wdt_enable=True) as dut:
  18. dut.expect_gme("Interrupt wdt timeout on CPU0")
  19. dut.expect_reg_dump(0)
  20. dut.expect_backtrace()
  21. dut.expect_none("Guru Meditation")
  22. dut.expect_reg_dump(1)
  23. dut.expect_backtrace()
  24. dut.expect_elf_sha256()
  25. dut.expect_none("Guru Meditation")
  26. dut.expect("Rebooting...")
  27. @panic_test()
  28. def test_cache_error(env, extra_data):
  29. with get_dut(env, "panic", "test_cache_error") as dut:
  30. dut.expect("Re-enable cpu cache.")
  31. dut.expect_gme("Cache disabled but cached memory region accessed")
  32. dut.expect_reg_dump(0)
  33. dut.expect_backtrace()
  34. dut.expect_elf_sha256()
  35. dut.expect_none("Guru Meditation")
  36. dut.expect("Rebooting...")
  37. @panic_test()
  38. def test_panic_int_wdt_cache_disabled(env, extra_data):
  39. with get_dut(env, "panic", "test_int_wdt_cache_disabled", qemu_wdt_enable=True) as dut:
  40. dut.expect("Re-enable cpu cache.")
  41. dut.expect_gme("Interrupt wdt timeout on CPU0")
  42. dut.expect_reg_dump(0)
  43. dut.expect_backtrace()
  44. dut.expect_none("Guru Meditation")
  45. dut.expect_reg_dump(1)
  46. dut.expect_backtrace()
  47. dut.expect_elf_sha256()
  48. dut.expect_none("Guru Meditation")
  49. dut.expect("Rebooting...")
  50. @panic_test()
  51. def test_panic_abort(env, extra_data):
  52. with get_dut(env, "panic", "test_abort") as dut:
  53. dut.expect(re.compile(r"abort\(\) was called at PC [0-9xa-f]+ on core 0"))
  54. dut.expect_none("register dump:")
  55. dut.expect_backtrace()
  56. dut.expect_none("Guru Meditation")
  57. dut.expect("Rebooting...")
  58. @panic_test()
  59. def test_panic_storeprohibited(env, extra_data):
  60. with get_dut(env, "panic", "test_storeprohibited") as dut:
  61. dut.expect_gme("StoreProhibited")
  62. dut.expect_reg_dump(0)
  63. dut.expect_backtrace()
  64. dut.expect_elf_sha256()
  65. dut.expect_none("Guru Meditation")
  66. dut.expect("Rebooting...")
  67. @panic_test()
  68. def test_panic_stack_overflow(env, extra_data):
  69. with get_dut(env, "panic", "test_stack_overflow") as dut:
  70. dut.expect_gme("Unhandled debug exception")
  71. dut.expect("Stack canary watchpoint triggered (main)")
  72. dut.expect_reg_dump(0)
  73. dut.expect_backtrace()
  74. dut.expect_elf_sha256()
  75. dut.expect_none("Guru Meditation")
  76. dut.expect("Rebooting...")
  77. @panic_test()
  78. def test_panic_illegal_instruction(env, extra_data):
  79. with get_dut(env, "panic", "test_illegal_instruction") as dut:
  80. dut.expect_gme("IllegalInstruction")
  81. dut.expect_reg_dump(0)
  82. dut.expect_backtrace()
  83. dut.expect_elf_sha256()
  84. dut.expect_none("Guru Meditation")
  85. dut.expect("Rebooting...")
  86. @panic_test()
  87. def test_panic_instr_fetch_prohibited(env, extra_data):
  88. with get_dut(env, "panic", "test_instr_fetch_prohibited") as dut:
  89. dut.expect_gme("InstrFetchProhibited")
  90. dut.expect_reg_dump(0)
  91. dut.expect_backtrace()
  92. dut.expect_elf_sha256()
  93. dut.expect_none("Guru Meditation")
  94. dut.expect("Rebooting...")
  95. @panic_test()
  96. def test_coredump_uart_abort(env, extra_data):
  97. with get_dut(env, "coredump_uart", "test_abort") as dut:
  98. dut.expect(re.compile(r"abort\(\) was called at PC [0-9xa-f]+ on core 0"))
  99. dut.expect_backtrace()
  100. dut.expect_elf_sha256()
  101. dut.expect_none("Guru Meditation", "Re-entered core dump")
  102. dut.expect(dut.COREDUMP_UART_END)
  103. dut.expect("Rebooting...")
  104. dut.process_coredump_uart()
  105. # TODO: check the contents of core dump output
  106. @panic_test()
  107. def test_coredump_uart_int_wdt(env, extra_data):
  108. with get_dut(env, "coredump_uart", "test_int_wdt") as dut:
  109. dut.expect_gme("Interrupt wdt timeout on CPU0")
  110. dut.expect_reg_dump(0)
  111. dut.expect("Backtrace:")
  112. dut.expect_none("CORRUPTED", "Guru Meditation")
  113. dut.expect_reg_dump(1)
  114. dut.expect("Backtrace:")
  115. dut.expect_elf_sha256()
  116. dut.expect_none("CORRUPTED", "Guru Meditation")
  117. dut.expect("Rebooting...")
  118. dut.process_coredump_uart()
  119. # TODO: check the contents of core dump output
  120. @panic_test()
  121. def test_coredump_flash_abort(env, extra_data):
  122. with get_dut(env, "coredump_flash", "test_abort") as dut:
  123. dut.expect(re.compile(r"abort\(\) was called at PC [0-9xa-f]+ on core 0"))
  124. dut.expect_backtrace()
  125. dut.expect_elf_sha256()
  126. dut.expect_none("Guru Meditation", "Re-entered core dump")
  127. dut.expect("Rebooting...")
  128. dut.process_coredump_flash()
  129. # TODO: check the contents of core dump output
  130. @panic_test()
  131. def test_coredump_flash_int_wdt(env, extra_data):
  132. with get_dut(env, "coredump_flash", "test_int_wdt") as dut:
  133. dut.expect_gme("Interrupt wdt timeout on CPU0")
  134. dut.expect_reg_dump(0)
  135. dut.expect("Backtrace:")
  136. dut.expect_none("CORRUPTED", "Guru Meditation")
  137. dut.expect_reg_dump(1)
  138. dut.expect("Backtrace:")
  139. dut.expect_elf_sha256()
  140. dut.expect_none("CORRUPTED", "Guru Meditation")
  141. dut.expect("Rebooting...")
  142. dut.process_coredump_flash()
  143. # TODO: check the contents of core dump output
  144. if __name__ == '__main__':
  145. run_all(__file__)