summaryrefslogtreecommitdiff
path: root/tests/esp32
diff options
context:
space:
mode:
Diffstat (limited to 'tests/esp32')
-rw-r--r--tests/esp32/check_err_str.py43
-rw-r--r--tests/esp32/check_err_str.py.exp4
2 files changed, 47 insertions, 0 deletions
diff --git a/tests/esp32/check_err_str.py b/tests/esp32/check_err_str.py
new file mode 100644
index 000000000..055eecf74
--- /dev/null
+++ b/tests/esp32/check_err_str.py
@@ -0,0 +1,43 @@
+try:
+ from esp32 import Partition as p
+ import micropython
+except ImportError:
+ print("SKIP")
+ raise SystemExit
+
+# try some vanilla OSError to get std error code
+try:
+ open("this filedoesnotexist", "r")
+ print("FAILED TO RAISE")
+except OSError as e:
+ print(e)
+
+# try to make nvs partition bootable, which ain't gonna work
+part = p.find(type=p.TYPE_DATA)[0]
+fun = p.set_boot
+try:
+ fun(part)
+ print("FAILED TO RAISE")
+except OSError as e:
+ print(e)
+
+# same but with out of memory condition by locking the heap
+exc = "FAILED TO RAISE"
+micropython.heap_lock()
+try:
+ fun(part)
+except OSError as e:
+ exc = e
+micropython.heap_unlock()
+print("exc:", exc) # exc empty due to no memory
+
+# same again but having an emergency buffer
+micropython.alloc_emergency_exception_buf(256)
+exc = "FAILED TO RAISE"
+micropython.heap_lock()
+try:
+ fun(part)
+except Exception as e:
+ exc = e
+micropython.heap_unlock()
+print(exc)
diff --git a/tests/esp32/check_err_str.py.exp b/tests/esp32/check_err_str.py.exp
new file mode 100644
index 000000000..d4162d1be
--- /dev/null
+++ b/tests/esp32/check_err_str.py.exp
@@ -0,0 +1,4 @@
+[Errno 2] ENOENT
+(-5379, 'ESP_ERR_OTA_VALIDATE_FAILED')
+exc:
+-5379