summaryrefslogtreecommitdiff
path: root/src/test/lib/test_lib.sail
diff options
context:
space:
mode:
authorRobert Norton2017-06-29 17:30:53 +0100
committerRobert Norton2017-06-29 17:30:53 +0100
commitacfa76485c252aa2a6df199aeeaf9af6b4dc4930 (patch)
treeb827ad442e8a2b93fa844db553de1214e985230e /src/test/lib/test_lib.sail
parent044403657d09aed9c56a9bca6decc864ed987f69 (diff)
beginnings of a sail library test suite.
Diffstat (limited to 'src/test/lib/test_lib.sail')
-rw-r--r--src/test/lib/test_lib.sail68
1 files changed, 68 insertions, 0 deletions
diff --git a/src/test/lib/test_lib.sail b/src/test/lib/test_lib.sail
new file mode 100644
index 00000000..bcabe2cc
--- /dev/null
+++ b/src/test/lib/test_lib.sail
@@ -0,0 +1,68 @@
+
+
+scattered typedef ast = const union
+val ast -> unit effect pure execute
+scattered function unit execute
+
+union ast member (unit) DUMMY
+function clause execute (DUMMY) = ()
+
+end ast
+end execute
+
+(*val extern string -> unit effect {wmv} printt*)
+
+function unit test_assert (name, pred) = {
+ print (name);
+ if pred then
+ print (": pass\n")
+ else
+ print(": fail\n")
+}
+
+function (bit[64]) run ((bit[64]) x) = {
+ test_assert ("not_bit0", (not (bitzero)) == bitone);
+ test_assert ("not_bit1", (not (bitone)) == bitzero);
+
+
+ test_assert ("bitwise_not", (~ (0b01) == 0b10));
+ test_assert ("bitwise_not_bit0", (~ (bitzero) == bitone));
+ test_assert ("bitwise_not_bit1", (~ (bitone) == bitzero));
+
+ test_assert ("bitwise_or", (0b0101 | 0b0011) == 0b0111);
+ test_assert ("bitwise_or_00", (bitzero | bitzero) == bitzero);
+ test_assert ("bitwise_or_01", (bitzero | bitone) == bitone);
+ test_assert ("bitwise_or_10", (bitone | bitzero) == bitone);
+ test_assert ("bitwise_or_11", (bitone | bitone) == bitone);
+
+ test_assert ("bitwise_xor", (0b0101 ^ 0b0011) == 0b0110);
+ (*
+ XXX something in here causes sail to infinite loop
+ test_assert ("bitwise_xor_00", (bitzero ^ bitzero) == bitzero);
+ test_assert ("bitwise_xor_01", (bitzero ^ bitone) == bitone);
+ test_assert ("bitwise_xor_10", (bitone ^ bitzero) == bitone);
+ test_assert ("bitwise_xor_11", (bitone ^ bitone) == bitzero);*)
+
+ test_assert ("bitwise_and", (0b0101 & 0b0011) == 0b0001);
+ test_assert ("bitwise_and_00", (bitzero & bitzero) == bitzero);
+ test_assert ("bitwise_and_01", (bitzero & bitone) == bitzero);
+ test_assert ("bitwise_and_10", (bitone & bitzero) == bitzero);
+ test_assert ("bitwise_and_11", (bitone & bitone) == bitone);
+
+ test_assert ("divpospos_exact", (21 div 7) == 3);
+ test_assert ("divposneg_exact", (21 div -7) == -3);
+ test_assert ("divnegpos_exact", (-21 div 7) == -3);
+ test_assert ("divnegneg_exact", (-21 div -7) == 3);
+
+ test_assert ("divpospos_approx", (21 div 8) == 2);
+ test_assert ("divposneg_approx", (21 div -8) == -2);
+ test_assert ("divnegpos_approx", (-21 div 8) == -2);
+ test_assert ("divnegneg_approx", (-21 div -8) == 2);
+
+ (* XXX currently crashes on shallow embedding
+ test_assert ("div_overflow", ((bit[8])(0x80 quot_s 0xff)) == 0x80);
+ *)
+
+ return 0;
+}
+