InsertDefaultsTest.php 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <?php
  2. namespace Drupal\KernelTests\Core\Database;
  3. use Drupal\Core\Database\Query\NoFieldsException;
  4. /**
  5. * Tests the Insert query builder with default values.
  6. *
  7. * @group Database
  8. */
  9. class InsertDefaultsTest extends DatabaseTestBase {
  10. /**
  11. * Tests that we can run a query that uses default values for everything.
  12. */
  13. public function testDefaultInsert() {
  14. $query = $this->connection->insert('test')->useDefaults(['job']);
  15. $id = $query->execute();
  16. $schema = drupal_get_module_schema('database_test', 'test');
  17. $job = $this->connection->query('SELECT job FROM {test} WHERE id = :id', [':id' => $id])->fetchField();
  18. $this->assertEqual($job, $schema['fields']['job']['default'], 'Default field value is set.');
  19. }
  20. /**
  21. * Tests that no action will be preformed if no fields are specified.
  22. */
  23. public function testDefaultEmptyInsert() {
  24. $num_records_before = (int) $this->connection->query('SELECT COUNT(*) FROM {test}')->fetchField();
  25. try {
  26. $this->connection->insert('test')->execute();
  27. // This is only executed if no exception has been thrown.
  28. $this->fail('Expected exception NoFieldsException has not been thrown.');
  29. }
  30. catch (NoFieldsException $e) {
  31. // Expected exception; just continue testing.
  32. }
  33. $num_records_after = (int) $this->connection->query('SELECT COUNT(*) FROM {test}')->fetchField();
  34. $this->assertSame($num_records_before, $num_records_after, 'Do nothing as no fields are specified.');
  35. }
  36. /**
  37. * Tests that we can insert fields with values and defaults in the same query.
  38. */
  39. public function testDefaultInsertWithFields() {
  40. $query = $this->connection->insert('test')
  41. ->fields(['name' => 'Bob'])
  42. ->useDefaults(['job']);
  43. $id = $query->execute();
  44. $schema = drupal_get_module_schema('database_test', 'test');
  45. $job = $this->connection->query('SELECT job FROM {test} WHERE id = :id', [':id' => $id])->fetchField();
  46. $this->assertEqual($job, $schema['fields']['job']['default'], 'Default field value is set.');
  47. }
  48. }