getConnection()->getSchema()->getServerVersion(), '5.7', '<')) { $this->markTestSkipped('JSON columns are not supported in MySQL < 5.7'); } if (version_compare(PHP_VERSION, '5.6', '<')) { $this->markTestSkipped('JSON columns are not supported in PDO for PHP < 5.6'); } $data = [ 'obj' => ['a' => ['b' => ['c' => 2.7418]]], 'array' => [1,2,null,3], 'null_field' => null, 'boolean_field' => true, 'last_update_time' => '2018-02-21', ]; $storage = new Storage(['data' => $data]); $this->assertTrue($storage->save(), 'Storage can be saved'); $this->assertNotNull($storage->id); $retrievedStorage = Storage::findOne($storage->id); $this->assertSame($data, $retrievedStorage->data, 'Properties are restored from JSON to array without changes'); $retrievedStorage->data = ['updatedData' => $data]; $this->assertSame(1, $retrievedStorage->update(), 'Storage can be updated'); $retrievedStorage->refresh(); $this->assertSame(['updatedData' => $data], $retrievedStorage->data, 'Properties have been changed during update'); } }