From 453f0a0d7346c16b327e39520374a555ecc8f2e4 Mon Sep 17 00:00:00 2001 From: nsfisis Date: Sun, 28 Apr 2024 17:47:20 +0900 Subject: test: check trap error message --- tests/src/SpecTestsuites/SpecTestsuiteBase.php | 24 ++++++++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) (limited to 'tests/src') diff --git a/tests/src/SpecTestsuites/SpecTestsuiteBase.php b/tests/src/SpecTestsuites/SpecTestsuiteBase.php index 72d1a86..1aa37de 100644 --- a/tests/src/SpecTestsuites/SpecTestsuiteBase.php +++ b/tests/src/SpecTestsuites/SpecTestsuiteBase.php @@ -8,6 +8,7 @@ use Nsfisis\Waddiwasi\BinaryFormat\Decoder; use Nsfisis\Waddiwasi\Execution\Runtime; use Nsfisis\Waddiwasi\Execution\Store; use Nsfisis\Waddiwasi\Execution\TrapException; +use Nsfisis\Waddiwasi\Execution\TrapKind; use PHPUnit\Framework\TestCase; use function count; @@ -84,7 +85,7 @@ abstract class SpecTestsuiteBase extends TestCase $exception = $e; } $this->assertNotNull($exception, "at $line"); - // @todo check trap message + $this->assertTrapKind($text, $e->getTrapKind(), "at $line"); } else { $this->assertTrue(false, "assert_trap: unknown action, $actionType"); } @@ -176,7 +177,7 @@ abstract class SpecTestsuiteBase extends TestCase $this->assertCount( count($expectedResults), $actualResults, - "results count mismatch" . $message, + 'results count mismatch' . $message, ); for ($i = 0; $i < count($expectedResults); $i++) { @@ -222,4 +223,23 @@ abstract class SpecTestsuiteBase extends TestCase } } } + + private function assertTrapKind( + string $expectedErrorMessage, + TrapKind $kind, + string $message = '', + ): void { + if ($message !== '') { + $message = " ($message)"; + } + $actualErrorMessage = match ($kind) { + TrapKind::OutOfBoundsMemoryAccess => 'out of bounds memory access', + TrapKind::Unknown => 'unknown', + }; + $this->assertSame( + $expectedErrorMessage, + $actualErrorMessage, + 'trap kind mismatch' . $message, + ); + } } -- cgit v1.2.3-70-g09d2