/** * @group DataModel * @group DataModelGetIdFieldName * @covers FOF30\Model\DataModel::getIdFieldName */ public function testGetIdFieldName() { $config = array('idFieldName' => 'foftest_bare_id', 'tableName' => '#__foftest_bares'); $model = new DataModelStub(self::$container, $config); $id = $model->getIdFieldName(); $this->assertEquals('foftest_bare_id', $id, 'DataModel::getIdFieldName Failed to return the table column id'); }
/** * @group DataModel * @group DataModelMove * @covers FOF30\Model\DataModel::move * @dataProvider SpecialColumnsDataprovider::getTestMove */ public function testMove($test, $check) { // Please note that if you try to debug this test, you'll get a "Couldn't fetch mysqli_result" error // That's harmless and appears in debug only, you might want to suppress exception thowing //\PHPUnit_Framework_Error_Warning::$enabled = false; $before = 0; $beforeDisp = 0; $after = 0; $afterDisp = 0; $db = \JFactory::getDbo(); $msg = 'DataModel::move %s - Case: ' . $check['case']; $config = array('idFieldName' => 'foftest_foobar_id', 'tableName' => '#__foftest_foobars'); // I am passing those methods so I can double check if the method is really called $methods = array('onBeforeMove' => function () use(&$before) { $before++; }, 'onAfterMove' => function () use(&$after) { $after++; }); $model = new DataModelStub(static::$container, $config, $methods); $dispatcher = $model->getBehavioursDispatcher(); // Let's attach a custom observer, so I can mock and check all the calls performed by the dispatcher // P.A. The object is immediatly attached to the dispatcher, so I don't need to manually do that new ObserverClosure($dispatcher, array('onBeforeMove' => function (&$subject, &$delta, &$where) use($test, &$beforeDisp) { if (!is_null($test['mock']['find'])) { $subject->find($test['mock']['find']); } if (!is_null($test['mock']['delta'])) { $delta = $test['mock']['delta']; } if (!is_null($test['mock']['where'])) { $where = $test['mock']['where']; } $beforeDisp++; }, 'onAfterMove' => function () use(&$afterDisp) { $afterDisp++; })); if ($test['id']) { $model->find($test['id']); } $result = $model->move($test['delta'], $test['where']); // Now let's take a look at the updated records $query = $db->getQuery(true)->select('ordering')->from($db->qn('#__foftest_foobars'))->order($db->qn($model->getIdFieldName()) . ' ASC'); $ordering = $db->setQuery($query)->loadColumn(); $this->assertInstanceOf('\\FOF30\\Model\\DataModel', $result, sprintf($msg, 'Should return an instance of itself')); $this->assertEquals(1, $before, sprintf($msg, 'Failed to invoke the onBefore method')); $this->assertEquals(1, $beforeDisp, sprintf($msg, 'Failed to invoke the onBeforeMove event')); $this->assertEquals(1, $after, sprintf($msg, 'Failed to invoke the onAfter method')); $this->assertEquals(1, $afterDisp, sprintf($msg, 'Failed to invoke the onAfterMove event')); $this->assertEquals($check['order'], $ordering, sprintf($msg, 'Failed to save the correct order')); }