You are here

public function UpdateLobTest::testUpdateOneBlob in Drupal 8

Same name and namespace in other branches
  1. 9 core/tests/Drupal/KernelTests/Core/Database/UpdateLobTest.php \Drupal\KernelTests\Core\Database\UpdateLobTest::testUpdateOneBlob()

Confirms that we can update a blob column.

File

core/tests/Drupal/KernelTests/Core/Database/UpdateLobTest.php, line 17

Class

UpdateLobTest
Tests the Update query builder with LOB fields.

Namespace

Drupal\KernelTests\Core\Database

Code

public function testUpdateOneBlob() {
  $data = "This is\0a test.";
  $this
    ->assertTrue(strlen($data) === 15, 'Test data contains a NULL.');
  $id = $this->connection
    ->insert('test_one_blob')
    ->fields([
    'blob1' => $data,
  ])
    ->execute();
  $data .= $data;
  $this->connection
    ->update('test_one_blob')
    ->condition('id', $id)
    ->fields([
    'blob1' => $data,
  ])
    ->execute();
  $r = $this->connection
    ->query('SELECT * FROM {test_one_blob} WHERE id = :id', [
    ':id' => $id,
  ])
    ->fetchAssoc();
  $this
    ->assertTrue($r['blob1'] === $data, new FormattableMarkup('Can update a blob: id @id, @data.', [
    '@id' => $id,
    '@data' => serialize($r),
  ]));
}