65 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * @author Daniel J. Summers <daniel@bitbadger.solutions>
 | |
|  * @license MIT
 | |
|  */
 | |
| 
 | |
| declare(strict_types=1);
 | |
| 
 | |
| use BitBadger\PDODocument\{Count, Delete, Field};
 | |
| use Test\Integration\PostgreSQL\ThrowawayDb;
 | |
| 
 | |
| pest()->group('integration', 'postgresql');
 | |
| 
 | |
| describe('::byId()', function () {
 | |
|     test('deletes a document when ID is matched', function () {
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|         Delete::byId(ThrowawayDb::TABLE, 'four');
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(4);
 | |
|     });
 | |
|     test('does not delete a document when ID is not matched', function () {
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|         Delete::byId(ThrowawayDb::TABLE, 'negative four');
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|     });
 | |
| });
 | |
| 
 | |
| describe('::byFields()', function () {
 | |
|     test('deletes documents when fields match', function () {
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|         Delete::byFields(ThrowawayDb::TABLE, [Field::notEqual('value', 'purple')]);
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(2);
 | |
|     });
 | |
|     test('does not delete documents when fields are not matched', function () {
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|         Delete::byFields(ThrowawayDb::TABLE, [Field::equal('value', 'crimson')]);
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|     });
 | |
| });
 | |
| 
 | |
| describe('::byContains()', function () {
 | |
|     test('deletes documents when containment matches', function () {
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|         Delete::byContains(ThrowawayDb::TABLE, ['value' => 'purple']);
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(3);
 | |
|     });
 | |
|     test('does not delete documents when containment is not matched', function () {
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|         Delete::byContains(ThrowawayDb::TABLE, ['target' => 'acquired']);
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|     });
 | |
| });
 | |
| 
 | |
| describe('::byJsonPath()', function () {
 | |
|     test('deletes documents when path matches', function () {
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|         Delete::byJsonPath(ThrowawayDb::TABLE, '$.num_value ? (@ <> 0)');
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(1);
 | |
|     });
 | |
|     test('does not delete documents when path is not matched', function () {
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|         Delete::byJsonPath(ThrowawayDb::TABLE, '$.num_value ? (@ < 0)');
 | |
|         expect(Count::all(ThrowawayDb::TABLE))->toBe(5);
 | |
|     });
 | |
| });
 |