Skip to content

Commit

Permalink
feat(WPDb) add see|dontSee|grab|dontHave (site)transient methods, fixes
Browse files Browse the repository at this point in the history
  • Loading branch information
lucatume committed Oct 14, 2023
1 parent fc8d498 commit a5144fe
Show file tree
Hide file tree
Showing 11 changed files with 1,550 additions and 17 deletions.
53 changes: 53 additions & 0 deletions docs/modules/WPDb.md
Original file line number Diff line number Diff line change
Expand Up @@ -565,6 +565,16 @@ $I->dontSeeSiteOptionInDatabase('foo_count', 23);
$I->dontSeeSiteOptionInDatabase(['option_name => 'foo_count', 'option_value' => 23]);
```

#### dontSeeSiteTransientInDatabase
Signature: `dontSeeSiteTransientInDatabase(string $transient, [mixed $value])` : `void`

Checks that a site transient is not in the database.

```php
<?php
$I->dontSeeSiteTransientInDatabase('foo');
$I->dontSeeSiteTransientInDatabase('foo', 23);
```
#### dontSeeTableInDatabase
Signature: `dontSeeTableInDatabase(string $table)` : `void`

Expand Down Expand Up @@ -615,6 +625,16 @@ list($termId, $termTaxonomyId) = $I->haveTermInDatabase('fiction', 'genre');
$I->dontSeeTermTaxonomyInDatabase(['term_id' => $termId, 'taxonomy' => 'country']);
```

#### dontSeeTransientInDatabase
Signature: `dontSeeTransientInDatabase(string $transient, [mixed $value])` : `void`

Checks that a transient is not in the database.

```php
<?php
$I->dontSeeTransientInDatabase('foo');
$I->dontSeeTransientInDatabase('foo', 23);
```
#### dontSeeUserInDatabase
Signature: `dontSeeUserInDatabase(array $criteria)` : `void`

Expand Down Expand Up @@ -1200,6 +1220,17 @@ $I->useBlog(23);
$I->grabTermsTableName();
```

#### grabTransientFromDatabase
Signature: `grabTransientFromDatabase(string $transient)` : `mixed`

Fetches the value of a transient from the database.

```php
<?php
$I->haveTransientInDatabase('foo', 23);
$transientValue = $I->grabTransientFromDatabase('foo');
$I->assertEquals(23, $transientValue);
```
#### grabUserIdFromDatabase
Signature: `grabUserIdFromDatabase(string $userLogin)` : `int|false`

Expand Down Expand Up @@ -1932,6 +1963,17 @@ $I->seeSiteSiteTransientInDatabase('total_counts');
$I->seeSiteSiteTransientInDatabase('total_counts', 23);
```

#### seeSiteTransientInDatabase
Signature: `seeSiteTransientInDatabase(string $transient, [mixed $value])` : `void`

Checks that a site transient is in the database.

```php
<?php
$I->haveSiteTransientInDatabase('foo', 23);
$I->seeSiteTransientInDatabase('foo');
$I->seeSiteTransientInDatabase('foo', 23);
```
#### seeTableInDatabase
Signature: `seeTableInDatabase(string $table)` : `void`

Expand Down Expand Up @@ -1989,6 +2031,17 @@ list($termId, $termTaxonomyId) = $I->haveTermInDatabase('fiction', 'genre');
$I->seeTermTaxonomyInDatabase(['term_id' => $termId, 'taxonomy' => 'genre']);
```

#### seeTransientInDatabase
Signature: `seeTransientInDatabase(string $name, [mixed $value])` : `void`

Checks that a transient is in the database.

```php
<?php
$I->haveTransientInDatabase('foo', 23);
$I->seeTransientInDatabase('foo');
$I->seeTransientInDatabase('foo', 23);
```
#### seeUserInDatabase
Signature: `seeUserInDatabase(array $criteria)` : `void`

Expand Down
113 changes: 113 additions & 0 deletions src/Module/WPDb.php
Original file line number Diff line number Diff line change
Expand Up @@ -4792,4 +4792,117 @@ protected function normalizeOptionCriteria(array|string $criteriaOrName, mixed $

return $criteria;
}

/**
* Fetches the value of a transient from the database.
*
* @example
* ```php
* $I->haveTransientInDatabase('foo', 23);
* $transientValue = $I->grabTransientFromDatabase('foo');
* $I->assertEquals(23, $transientValue);
* ```
* @param string $transient The transient name.
*
* @return mixed The transient value; it will be unserialized if it was serialized.
*
*/
public function grabTransientFromDatabase(string $transient): mixed
{
$transient = $this->normalizePrefixedOptionName($transient, '_transient_');
return $this->grabOptionFromDatabase($transient);
}

/**
* Checks that a transient is not in the database.
*
* @example
* ```php
* $I->dontSeeTransientInDatabase('foo');
* $I->dontSeeTransientInDatabase('foo', 23);
* ```
* @param mixed $value The optional value to try and match.
*
* @param string $transient The transient name.
* @return void
* @throws JsonException
*
*/
public function dontSeeTransientInDatabase(string $transient, mixed $value = null): void
{
$transient = $this->normalizePrefixedOptionName($transient, '_transient_');
$this->dontSeeOptionInDatabase($transient, $value);
}

/**
* Checks that a transient is in the database.
*
* @example
* ```php
* $I->haveTransientInDatabase('foo', 23);
* $I->seeTransientInDatabase('foo');
* $I->seeTransientInDatabase('foo', 23);
* ```
* @param mixed $value The optional value to try and match.
*
* @param string $name The transient name.
* @return void
* @throws JsonException
*
*/
public function seeTransientInDatabase(string $name, mixed $value = null): void
{
$transient = $this->normalizePrefixedOptionName($name, '_transient_');
$this->seeOptionInDatabase($transient, $value);
}

/**
* Checks that a site transient is not in the database.
*
* @example
* ```php
* $I->dontSeeSiteTransientInDatabase('foo');
* $I->dontSeeSiteTransientInDatabase('foo', 23);
* ```
* @param mixed|null $value The optional value to try and match.
*
* @param string $transient The transient name.
* @return void
*
* @throws JsonException|ModuleException
*
*/
public function dontSeeSiteTransientInDatabase(string $transient, mixed $value = null): void
{
$currentBlogId = $this->blogId;
$this->useMainBlog();
$transient = $this->normalizePrefixedOptionName($transient, '_site_transient_');
$this->dontSeeOptionInDatabase($transient, $value);
$this->useBlog($currentBlogId);
}

/**
* Checks that a site transient is in the database.
*
* @example
* ```php
* $I->haveSiteTransientInDatabase('foo', 23);
* $I->seeSiteTransientInDatabase('foo');
* $I->seeSiteTransientInDatabase('foo', 23);
* ```
* @param mixed|null $value The optional value to try and match.
*
* @param string $transient The transient name.
* @return void
* @throws JsonException|ModuleException
*
*/
public function seeSiteTransientInDatabase(string $transient, mixed $value = null): void
{
$currentBlogId = $this->blogId;
$this->useMainBlog();
$transient = $this->normalizePrefixedOptionName($transient, '_site_transient_');
$this->seeOptionInDatabase($transient, $value);
$this->useBlog($currentBlogId);
}
}
Loading

0 comments on commit a5144fe

Please sign in to comment.