$user = new User(array('name' => $name, 'email' => "{$name}@not_a_domain.com", 'created_at' => new PlainSql('NOW()'), 'active' => 1)); $user->save(); } OrmTest::assertTrue('Testing save() on new object.', is_numeric($user->getId())); $user->setName("{$name} Johnson")->save(); OrmTest::assertTrue('Testing updating field on hydrated object.', $user->getName() === "{$name} Johnson"); $user->setName($name)->save(); $id = $user->getId(); $user = new User($id); OrmTest::assertTrue('Testing fetching object by id on new object.', $user->getName() === $name); $users = User::select('1=?', 1); OrmTest::assertTrue('Testing fetching objects by select() method.', count($users) === 4 and $users->current()->getName() !== ''); OrmTest::assertTrue('Testing array access by id of results set.', $users[$id]->getName() !== ''); $users = User::find(array('active' => 1)); OrmTest::assertTrue('Testing fetching objects by find() method.', count($users) === 4 and $users->current()->getName() !== ''); $user = User::one(array('name' => 'Jason')); OrmTest::assertTrue('Testing fetching object by one() method.', $user->getName() === 'Jason'); $phone = $user->create(new PhoneNumber(array('type' => 'home', 'number' => '607-000-0000'))); OrmTest::assertTrue('Testing create new object through create() method.', $phone instanceof PhoneNumber and $phone->getUserId() === $user->getId()); foreach (array(111, 222, 333, 444, 555) as $prefix) { $user->create(new PhoneNumber(array('type' => 'home', 'number' => '607-' . $prefix . '-0000', 'location' => null)))->save(); } OrmTest::assertTrue('Loading records to test method appication to entire results set.', true); PhoneNumber::select('`number` like "607%" and `location` IS NULL order by `number`')->setLocation('Ithaca, NY')->setType('Cell Phone')->save(); $phones = PhoneNumber::find(array('location' => 'Ithaca, NY', 'type' => 'Cell Phone')); OrmTest::assertTrue('Checking to see if method application applied correctly.', count($phones) === 5); OrmTest::assertTrue('Testing getRelationClassName style magic method (singular).', $user->getPhoneNumber()->getLocation() === 'Ithaca, NY'); OrmTest::assertTrue('Testing getRelationClassName style magic method (list) .', count($user->getPhoneNumber(true)) === 5 and $user->getPhoneNumber(true)->current()->getLocation() === 'Ithaca, NY'); OrmTest::assertTrue('Testing getRelationClassName style magic method (custom) .', $user->getPhoneNumber('`number` like ?', "%111%")->current()->getNumber() === '607-111-0000'); $post = $user->create(new Post(array('title' => 'test post', 'body' => "I ain't got no body.."))); $post->addMeta(array('background' => 'blue', 'border' => '1px solid grey'));
public function testDelete() { $user = new User(array('login' => 'user1', 'email' => '*****@*****.**', 'password' => 'secret')); $user->save(); $user = User::one(1); $user->delete(); $user1 = User::one(1); $this->assertNull($user1); }