From 877dffd460d15d91ba1cbb13010708b1fc3b5e46 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Miloslav=20H=C5=AFla?= Date: Sun, 4 Apr 2021 22:31:40 +0200 Subject: [PATCH] tests: use test() helper --- tests/dibi/Connection.transactions.phpt | 58 +++++++++++++------------ 1 file changed, 31 insertions(+), 27 deletions(-) diff --git a/tests/dibi/Connection.transactions.phpt b/tests/dibi/Connection.transactions.phpt index d0a74da4..a4953d90 100644 --- a/tests/dibi/Connection.transactions.phpt +++ b/tests/dibi/Connection.transactions.phpt @@ -30,42 +30,46 @@ Assert::exception(function () use ($conn) { */ -$conn->begin(); -Assert::same(3, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle()); -$conn->query('INSERT INTO [products]', [ - 'title' => 'Test product', -]); -Assert::same(4, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle()); -$conn->rollback(); -Assert::same(3, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle()); +test('begin() & rollback()', function () use ($conn) { + $conn->begin(); + Assert::same(3, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle()); + $conn->query('INSERT INTO [products]', [ + 'title' => 'Test product', + ]); + Assert::same(4, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle()); + $conn->rollback(); + Assert::same(3, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle()); +}); +test('begin() & commit()', function () use ($conn) { + $conn->begin(); + $conn->query('INSERT INTO [products]', [ + 'title' => 'Test product', + ]); + $conn->commit(); + Assert::same(4, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle()); +}); -$conn->begin(); -$conn->query('INSERT INTO [products]', [ - 'title' => 'Test product', -]); -$conn->commit(); -Assert::same(4, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle()); +test('transaction() fail', function () use ($conn) { + Assert::exception(function () use ($conn) { + $conn->transaction(function (Dibi\Connection $connection) { + $connection->query('INSERT INTO [products]', [ + 'title' => 'Test product', + ]); + throw new Exception('my exception'); + }); + }, \Throwable::class, 'my exception'); + Assert::same(4, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle()); +}); - -Assert::exception(function () use ($conn) { +test('transaction() success', function () use ($conn) { $conn->transaction(function (Dibi\Connection $connection) { $connection->query('INSERT INTO [products]', [ 'title' => 'Test product', ]); - throw new Exception('my exception'); }); -}, \Throwable::class, 'my exception'); - -Assert::same(4, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle()); - -$conn->transaction(function (Dibi\Connection $connection) { - $connection->query('INSERT INTO [products]', [ - 'title' => 'Test product', - ]); + Assert::same(5, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle()); }); - -Assert::same(5, (int) $conn->query('SELECT COUNT(*) FROM [products]')->fetchSingle());