diff options
author | Harald Eilertsen <haraldei@anduin.net> | 2021-04-15 00:52:54 +0200 |
---|---|---|
committer | Harald Eilertsen <haraldei@anduin.net> | 2021-04-15 00:52:54 +0200 |
commit | f8f01743b8b5256dda9e199f5d8e77ddb9eea278 (patch) | |
tree | f13001c67460cfab30c664ee80065823fb941c6d /tests/VenueTest.php | |
parent | 68df3cb908f8d6658fa39ef81a923bf8dc21509d (diff) | |
download | gigologadmin-f8f01743b8b5256dda9e199f5d8e77ddb9eea278.tar.gz gigologadmin-f8f01743b8b5256dda9e199f5d8e77ddb9eea278.tar.bz2 gigologadmin-f8f01743b8b5256dda9e199f5d8e77ddb9eea278.zip |
Fix test setup for wp-env.
After much reading I finally found the magic incantations, so now we can
run tests with real database access. This means we no longer need the
primitive $wpdb_stub.
The setup as now _requires_ wp-env, or an environment set up
sufficiently similar. Running in wp-env is the easiest, so aim for that.
I've added a `run-tests` script that will invoke the magic incantation
without having to remember it every time.
To set up for testing:
1. make sure you have composer[1] installed.
2. run `composer install`
3. make sure you have wp-env[2] installed
4. start the wordpress env: `wp-env start`
5. run the tests: `./run-tests`
Let the thousand tests bloom!
[1]: https://github.com/wp-phpunit/wp-phpunit
[2]: https://www.npmjs.com/package/@wordpress/env
Diffstat (limited to 'tests/VenueTest.php')
-rw-r--r-- | tests/VenueTest.php | 81 |
1 files changed, 30 insertions, 51 deletions
diff --git a/tests/VenueTest.php b/tests/VenueTest.php index bea6dc4..4278951 100644 --- a/tests/VenueTest.php +++ b/tests/VenueTest.php @@ -6,97 +6,76 @@ declare(strict_types=1); -use PHPUnit\Framework\TestCase; +require __DIR__ . '/../includes/venue.php'; -require 'tests/stubs/wpdb_stub.php'; -require 'includes/venue.php'; - -final class VenueTest extends TestCase +final class VenueTest extends WP_UnitTestCase { public function testCreatingVenueWithName(): void { + $count = count(GiglogAdmin_Venue::all_venues()); + $venue = GiglogAdmin_Venue::create("Svene Samfunns- og Bedehus"); $this->assertEquals("Svene Samfunns- og Bedehus", $venue->name()); - $this->assertEquals(1, $venue->id()); + + $this->assertEquals($count + 1, count(GiglogAdmin_Venue::all_venues())); } public function testFindOrCreateNonExistingVenue() : void { + $count = count(GiglogAdmin_Venue::all_venues()); + $venue = GiglogAdmin_Venue::find_or_create("Svene Samfunns- og Bedehus"); $this->assertEquals("Svene Samfunns- og Bedehus", $venue->name()); - $this->assertEquals(1, $venue->id()); + + $this->assertEquals($count + 1, count(GiglogAdmin_Venue::all_venues())); } public function testFindOrCreateExistingVenue() : void { global $wpdb; - $results = array( - (object) [ - 'id' => 42, - 'wpgvenue_name' => 'Slarkhaillen', - 'wpgvenue_city' => 'Ofoten', - 'wpgvenue_address' => 'Baillsvingen 4', - 'wpgvenue_webpage' => 'https://slarkhaillen.no' - ]); - - $wpdb = $this->createStub(wpdb::class); - $wpdb->method('get_results')->willReturn($results); - - $venue = GiglogAdmin_Venue::find_or_create("Slarkhaillen"); + $venue = GiglogAdmin_Venue::create("Svene Samfunns- og Bedehus"); + $other = GiglogAdmin_Venue::find_or_create("Svene Samfunns- og Bedehus"); - $this->assertEquals($results[0]->id, $venue->id()); - $this->assertEquals($results[0]->wpgvenue_name, $venue->name()); + $this->assertEquals($other->id(), $venue->id()); + $this->assertEquals($other->name(), $venue->name()); } public function testFindAllVenuesInCity() : void { global $wpdb; - $results = array(); for ($i = 0; $i < 3; $i++) { - $results[$i] = (object) [ - 'id' => 42 + $i, - 'wpgvenue_name' => "Venue #" . $i, - 'wpgvenue_city' => "Osaka" - ]; + GiglogAdmin_Venue::create("Venue in Osaka #" . $i, "Osaka"); } - $wpdb = $this->createStub(wpdb::class); - $wpdb->method('prepare')->willReturn("prepared"); - $wpdb->method('get_results')->willReturn($results); - - $venues = GiglogAdmin_Venue::venues_in_city("Osaka"); + for ($i = 0; $i < 5; $i++) { + GiglogAdmin_Venue::create("Venue in Berlin #" . $i, "Berlin"); + } - for ($i = 0; $i < 3; $i++) { - $this->assertEquals("Osaka", $venues[$i]->city()); - $this->assertEquals("Venue #" . $i, $venues[$i]->name()); - $this->assertEquals(42 + $i, $venues[$i]->id()); + for ($i = 0; $i < 2; $i++) { + GiglogAdmin_Venue::create("Venue in Svene #" . $i, "Svene"); } + + $venues_in_osaka = GiglogAdmin_Venue::venues_in_city("Osaka"); + $venues_in_berlin = GiglogAdmin_Venue::venues_in_city("Berlin"); + $venues_in_svene = GiglogAdmin_Venue::venues_in_city("Svene"); + + $this->assertEquals(3, count($venues_in_osaka)); + $this->assertEquals(5, count($venues_in_berlin)); + $this->assertEquals(2, count($venues_in_svene)); } public function testFindAllVenues() : void { global $wpdb; - $results = array(); for ($i = 0; $i < 3; $i++) { - $results[$i] = (object) [ - 'id' => 42 + $i, - 'wpgvenue_name' => "Venue #" . $i, - 'wpgvenue_city' => "City #" . $i - ]; + GiglogAdmin_Venue::create("Venue #" . $i); } - $wpdb = $this->createStub(wpdb::class); - $wpdb->method('get_results')->willReturn($results); - $venues = GiglogAdmin_Venue::all_venues(); + $this->assertEquals(3, count($venues)); - for ($i = 0; $i < 3; $i++) { - $this->assertEquals("City #" . $i, $venues[$i]->city()); - $this->assertEquals("Venue #" . $i, $venues[$i]->name()); - $this->assertEquals(42 + $i, $venues[$i]->id()); - } } } |