diff --git a/tests/pyb/i2c_error.py b/tests/pyb/i2c_error.py
new file mode 100644
index 0000000000000000000000000000000000000000..d6c0debe29e94cf8786a030987e79d6af6d89ea1
--- /dev/null
+++ b/tests/pyb/i2c_error.py
@@ -0,0 +1,50 @@
+# test I2C errors, with polling (disabled irqs) and DMA
+
+import pyb
+from pyb import I2C
+
+# init accelerometer
+pyb.Accel()
+
+# get I2C bus
+i2c = I2C(1, I2C.MASTER) 
+
+# test polling mem_read
+pyb.disable_irq()
+i2c.mem_read(1, 76, 0x0a) # should succeed
+pyb.enable_irq()
+try:
+    pyb.disable_irq()
+    i2c.mem_read(1, 77, 0x0a) # should fail
+except OSError as e:
+    pyb.enable_irq()
+    print(repr(e))
+i2c.mem_read(1, 76, 0x0a) # should succeed
+
+# test polling mem_write
+pyb.disable_irq()
+i2c.mem_write(1, 76, 0x0a) # should succeed
+pyb.enable_irq()
+try:
+    pyb.disable_irq()
+    i2c.mem_write(1, 77, 0x0a) # should fail
+except OSError as e:
+    pyb.enable_irq()
+    print(repr(e))
+i2c.mem_write(1, 76, 0x0a) # should succeed
+
+# test DMA mem_read
+i2c.mem_read(1, 76, 0x0a) # should succeed
+try:
+    i2c.mem_read(1, 77, 0x0a) # should fail
+except OSError as e:
+    print(repr(e))
+i2c.mem_read(1, 76, 0x0a) # should succeed
+
+# test DMA mem_write
+i2c.mem_write(1, 76, 0x0a) # should succeed
+try:
+    i2c.mem_write(1, 77, 0x0a) # should fail
+except OSError as e:
+    print(repr(e))
+i2c.mem_write(1, 76, 0x0a) # should succeed
diff --git a/tests/pyb/i2c_error.py.exp b/tests/pyb/i2c_error.py.exp
new file mode 100644
index 0000000000000000000000000000000000000000..bd403f7f47f8f8ec0a871ef9907a490235e95545
--- /dev/null
+++ b/tests/pyb/i2c_error.py.exp
@@ -0,0 +1,4 @@
+OSError(5,)
+OSError(5,)
+OSError(5,)
+OSError(5,)