Convert parser tests to filetests.

Create a new directory hierarchy under 'filetests' for all the tests
that are run by 'cton-util test'.

Convert the parser tests under 'tests/parser' to use 'test cat' and
filecheck directives.
This commit is contained in:
Jakob Stoklund Olesen
2016-09-15 15:27:37 -07:00
parent d221249e7f
commit 0b7f87b14c
13 changed files with 193 additions and 248 deletions

View File

@@ -0,0 +1,113 @@
; Parsing branches and jumps.
test cat
; Jumps with no arguments. The '()' empty argument list is optional.
function minimal() {
ebb0:
jump ebb1
ebb1:
jump ebb0()
}
; sameln: function minimal() {
; nextln: ebb0:
; nextln: jump ebb1
; nextln:
; nextln: ebb1:
; nextln: jump ebb0
; nextln: }
; Jumps with 1 arg.
function onearg(i32) {
ebb0(vx0: i32):
jump ebb1(vx0)
ebb1(vx1: i32):
jump ebb0(vx1)
}
; sameln: function onearg(i32) {
; nextln: ebb0(vx0: i32):
; nextln: jump ebb1(vx0)
; nextln:
; nextln: ebb1(vx1: i32):
; nextln: jump ebb0(vx1)
; nextln: }
; Jumps with 2 args.
function twoargs(i32, f32) {
ebb0(vx0: i32, vx1: f32):
jump ebb1(vx0, vx1)
ebb1(vx2: i32, vx3: f32):
jump ebb0(vx2, vx3)
}
; sameln: function twoargs(i32, f32) {
; nextln: ebb0(vx0: i32, vx1: f32):
; nextln: jump ebb1(vx0, vx1)
; nextln:
; nextln: ebb1(vx2: i32, vx3: f32):
; nextln: jump ebb0(vx2, vx3)
; nextln: }
; Branches with no arguments. The '()' empty argument list is optional.
function minimal(i32) {
ebb0(vx0: i32):
brz vx0, ebb1
ebb1:
brnz vx0, ebb1()
}
; sameln: function minimal(i32) {
; nextln: ebb0(vx0: i32):
; nextln: brz vx0, ebb1
; nextln:
; nextln: ebb1:
; nextln: brnz vx0, ebb1
; nextln: }
function twoargs(i32, f32) {
ebb0(vx0: i32, vx1: f32):
brz vx0, ebb1(vx0, vx1)
ebb1(vx2: i32, vx3: f32):
brnz vx0, ebb0(vx2, vx3)
}
; sameln: function twoargs(i32, f32) {
; nextln: ebb0(vx0: i32, vx1: f32):
; nextln: brz vx0, ebb1(vx0, vx1)
; nextln:
; nextln: ebb1(vx2: i32, vx3: f32):
; nextln: brnz vx0, ebb0(vx2, vx3)
; nextln: }
function jumptable(i32) {
jt200 = jump_table 0, 0
jt2 = jump_table 0, 0, ebb10, ebb40, ebb20, ebb30
ebb10(v3: i32):
br_table v3, jt2
trap
ebb20:
trap
ebb30:
trap
ebb40:
trap
}
; sameln: function jumptable(i32) {
; nextln: jt0 = jump_table 0
; nextln: jt1 = jump_table 0, 0, ebb0, ebb3, ebb1, ebb2
; nextln:
; nextln: ebb0(vx0: i32):
; nextln: br_table vx0, jt1
; nextln: trap
; nextln:
; nextln: ebb1:
; nextln: trap
; nextln:
; nextln: ebb2:
; nextln: trap
; nextln:
; nextln: ebb3:
; nextln: trap
; nextln: }

View File

@@ -0,0 +1,24 @@
; Parser tests for call and return syntax.
test cat
function mini() {
ebb1:
return
}
; sameln: function mini() {
; nextln: ebb0:
; nextln: return
; nextln: }
function r1() -> i32, f32 {
ebb1:
v1 = iconst.i32 3
v2 = f32const 0.0
return v1, v2
}
; sameln: function r1() -> i32, f32 {
; nextln: ebb0:
; nextln: v0 = iconst.i32 3
; nextln: v1 = f32const 0.0
; nextln: return v0, v1
; nextln: }

View File

@@ -6,6 +6,7 @@
; It is possible to refer to instructions and EBBs that have not yet been
; defined in the lexical order, so the parser needs to rewrite these references
; after the fact.
test cat
; Check that defining numbers are rewritten.
function defs() {
@@ -14,6 +15,12 @@ ebb100(v20: i32):
vx200 = f64const 0x4.0p0
trap
}
; sameln: function defs() {
; nextln: ebb0(vx0: i32):
; nextln: v0 = iconst.i32x8 5
; nextln: v1 = f64const 0x1.0000000000000p2
; nextln: trap
; nextln: }
; Using values.
function use_value() {
@@ -22,3 +29,9 @@ ebb100(v20: i32):
vx200 = iadd v20, v1000
jump ebb100(v1000)
}
; sameln: function "use_value"() {
; nextln: ebb0(vx0: i32):
; nextln: v0 = iadd_imm vx0, 5
; nextln: v1 = iadd vx0, v0
; nextln: jump ebb0(v0)
; nextln: }

View File

@@ -1,8 +1,14 @@
test cat
; The smallest possible function.
function minimal() {
ebb0:
trap
}
; sameln: function minimal() {
; nextln: ebb0:
; nextln: trap
; nextln: }
; Create and use values.
; Polymorphic instructions with type suffix.
@@ -12,12 +18,22 @@ ebb0:
v1 = iconst.i8 6
v2 = ishl v0, v1
}
; sameln: function ivalues() {
; nextln: ebb0:
; nextln: v0 = iconst.i32 2
; nextln: v1 = iconst.i8 6
; nextln: v2 = ishl v0, v1
; nextln: }
; Polymorphic istruction controlled by second operand.
function select() {
ebb0(vx0: i32, vx1: i32, vx2: b1):
v0 = select vx2, vx0, vx1
}
; sameln: function select() {
; nextln: ebb0(vx0: i32, vx1: i32, vx2: b1):
; nextln: v0 = select vx2, vx0, vx1
; nextln: }
; Lane indexes.
function lanes() {
@@ -26,6 +42,12 @@ ebb0:
v1 = extractlane v0, 3
v2 = insertlane v0, 1, v1
}
; sameln: function lanes() {
; nextln: ebb0:
; nextln: v0 = iconst.i32x4 2
; nextln: v1 = extractlane v0, 3
; nextln: v2 = insertlane v0, 1, v1
; nextln: }
; Integer condition codes.
function icmp(i32, i32) {
@@ -34,6 +56,12 @@ ebb0(vx0: i32, vx1: i32):
v1 = icmp ult, vx0, vx1
v2 = icmp sge, vx0, vx1
}
; sameln: function icmp(i32, i32) {
; nextln: ebb0(vx0: i32, vx1: i32):
; nextln: v0 = icmp eq, vx0, vx1
; nextln: v1 = icmp ult, vx0, vx1
; nextln: v2 = icmp sge, vx0, vx1
; nextln: }
; Floating condition codes.
function fcmp(f32, f32) {
@@ -42,6 +70,12 @@ ebb0(vx0: f32, vx1: f32):
v1 = fcmp uno, vx0, vx1
v2 = fcmp lt, vx0, vx1
}
; sameln: function fcmp(f32, f32) {
; nextln: ebb0(vx0: f32, vx1: f32):
; nextln: v0 = fcmp eq, vx0, vx1
; nextln: v1 = fcmp uno, vx0, vx1
; nextln: v2 = fcmp lt, vx0, vx1
; nextln: }
; The bitcast instruction has two type variables: The controlling type variable
; controls the outout type, and the input type is a free variable.
@@ -50,3 +84,8 @@ ebb0(vx0: i32, vx1: f32):
v0 = bitcast.i8x4 vx0
v1 = bitcast.i32 vx1
}
; sameln: function bitcast(i32, f32) {
; nextln: ebb0(vx0: i32, vx1: f32):
; nextln: v0 = bitcast.i8x4 vx0
; nextln: v1 = bitcast.i32 vx1
; nextln: }

View File

@@ -58,10 +58,12 @@ cargo build --release
export CTONUTIL="$topdir/src/tools/target/release/cton-util"
cd "$topdir"
banner "File tests"
"$CTONUTIL" test filetests
# Run the parser tests.
cd "$topdir/tests"
banner "Parser tests"
parser/run.sh
banner "CFG tests"
cfg/run.sh

View File

@@ -1,9 +0,0 @@
Parser tests
============
This directory contains test cases for the Cretonne IL parser.
Each test case consists of a `foo.cton` input file and a `foo.ref` reference
output file. Each input file is run through the `cton-util cat` command, and the
output is compared against the reference file. If the two are identical, the
test passes.

View File

@@ -1,60 +0,0 @@
; Parsing branches and jumps.
; Jumps with no arguments. The '()' empty argument list is optional.
function minimal() {
ebb0:
jump ebb1
ebb1:
jump ebb0()
}
; Jumps with 1 arg.
function onearg(i32) {
ebb0(vx0: i32):
jump ebb1(vx0)
ebb1(vx1: i32):
jump ebb0(vx1)
}
; Jumps with 2 args.
function twoargs(i32, f32) {
ebb0(vx0: i32, vx1: f32):
jump ebb1(vx0, vx1)
ebb1(vx2: i32, vx3: f32):
jump ebb0(vx2, vx3)
}
; Branches with no arguments. The '()' empty argument list is optional.
function minimal(i32) {
ebb0(vx0: i32):
brz vx0, ebb1
ebb1:
brnz vx0, ebb1()
}
function twoargs(i32, f32) {
ebb0(vx0: i32, vx1: f32):
brz vx0, ebb1(vx0, vx1)
ebb1(vx2: i32, vx3: f32):
brnz vx0, ebb0(vx2, vx3)
}
function jumptable(i32) {
jt200 = jump_table 0, 0
jt2 = jump_table 0, 0, ebb10, ebb40, ebb20, ebb30
ebb10(v3: i32):
br_table v3, jt2
trap
ebb20:
trap
ebb30:
trap
ebb40:
trap
}

View File

@@ -1,57 +0,0 @@
function minimal() {
ebb0:
jump ebb1
ebb1:
jump ebb0
}
function onearg(i32) {
ebb0(vx0: i32):
jump ebb1(vx0)
ebb1(vx1: i32):
jump ebb0(vx1)
}
function twoargs(i32, f32) {
ebb0(vx0: i32, vx1: f32):
jump ebb1(vx0, vx1)
ebb1(vx2: i32, vx3: f32):
jump ebb0(vx2, vx3)
}
function minimal(i32) {
ebb0(vx0: i32):
brz vx0, ebb1
ebb1:
brnz vx0, ebb1
}
function twoargs(i32, f32) {
ebb0(vx0: i32, vx1: f32):
brz vx0, ebb1(vx0, vx1)
ebb1(vx2: i32, vx3: f32):
brnz vx0, ebb0(vx2, vx3)
}
function jumptable(i32) {
jt0 = jump_table 0
jt1 = jump_table 0, 0, ebb0, ebb3, ebb1, ebb2
ebb0(vx0: i32):
br_table vx0, jt1
trap
ebb1:
trap
ebb2:
trap
ebb3:
trap
}

View File

@@ -1,13 +0,0 @@
; Parser tests for call and return syntax.
function mini() {
ebb1:
return
}
function r1() -> i32, f32 {
ebb1:
v1 = iconst.i32 3
v2 = f32const 0.0
return v1, v2
}

View File

@@ -1,11 +0,0 @@
function mini() {
ebb0:
return
}
function r1() -> i32, f32 {
ebb0:
v0 = iconst.i32 3
v1 = f32const 0.0
return v0, v1
}

View File

@@ -1,13 +0,0 @@
function defs() {
ebb0(vx0: i32):
v0 = iconst.i32x8 5
v1 = f64const 0x1.0000000000000p2
trap
}
function "use_value"() {
ebb0(vx0: i32):
v0 = iadd_imm vx0, 5
v1 = iadd vx0, v0
jump ebb0(v0)
}

View File

@@ -1,40 +0,0 @@
#!/bin/bash
# Go to tests directory.
cd $(dirname "$0")/..
# The path to cton-util should be in $CTONUTIL.
if [ -z "$CTONUTIL" ]; then
CTONUTIL=../src/tools/target/debug/cton-util
fi
if [ ! -x "$CTONUTIL" ]; then
echo "Can't fund executable cton-util: $CTONUTIL" 1>&2
exit 1
fi
declare -a fails
for testcase in $(find parser -name '*.cton'); do
ref="${testcase}.ref"
if [ ! -r "$ref" ]; then
fails=(${fails[@]} "$testcase")
echo MISSING: $ref
elif diff -u "$ref" <("$CTONUTIL" cat "$testcase"); then
echo OK $testcase
else
fails=(${fails[@]} "$testcase")
echo FAIL $testcase
fi
done
if [ ${#fails[@]} -ne 0 ]; then
echo
echo Failures:
for f in "${fails[@]}"; do
echo " $f"
done
exit 1
else
echo "All passed"
fi

View File

@@ -1,43 +0,0 @@
function minimal() {
ebb0:
trap
}
function ivalues() {
ebb0:
v0 = iconst.i32 2
v1 = iconst.i8 6
v2 = ishl v0, v1
}
function select() {
ebb0(vx0: i32, vx1: i32, vx2: b1):
v0 = select vx2, vx0, vx1
}
function lanes() {
ebb0:
v0 = iconst.i32x4 2
v1 = extractlane v0, 3
v2 = insertlane v0, 1, v1
}
function icmp(i32, i32) {
ebb0(vx0: i32, vx1: i32):
v0 = icmp eq, vx0, vx1
v1 = icmp ult, vx0, vx1
v2 = icmp sge, vx0, vx1
}
function fcmp(f32, f32) {
ebb0(vx0: f32, vx1: f32):
v0 = fcmp eq, vx0, vx1
v1 = fcmp uno, vx0, vx1
v2 = fcmp lt, vx0, vx1
}
function bitcast(i32, f32) {
ebb0(vx0: i32, vx1: f32):
v0 = bitcast.i8x4 vx0
v1 = bitcast.i32 vx1
}