2 require_once 'CiviTest/CiviUnitTestCase.php';
3 require_once 'CiviTest/Contact.php';
6 * Include dataProvider for tests
8 class CRM_Mailing_BAO_QueryTest
extends CiviUnitTestCase
{
11 * @return CRM_Mailing_BAO_QueryTestDataProvider
13 public function dataProvider() {
14 return new CRM_Mailing_BAO_QueryTestDataProvider();
17 public function setUp() {
21 public function tearDown() {
22 $tablesToTruncate = array(
23 'civicrm_mailing_event_bounce',
24 'civicrm_mailing_event_delivered',
25 'civicrm_mailing_event_opened',
26 'civicrm_mailing_event_reply',
27 'civicrm_mailing_event_trackable_url_open',
28 'civicrm_mailing_event_queue',
29 'civicrm_mailing_trackable_url',
30 'civicrm_mailing_job',
32 'civicrm_mailing_recipients',
36 $this->quickCleanup($tablesToTruncate);
40 * Test CRM_Contact_BAO_Query::searchQuery()
41 * @dataProvider dataProvider
47 public function testSearch($fv, $count, $ids, $full) {
48 $op = new PHPUnit_Extensions_Database_Operation_Insert();
49 $op->execute($this->_dbconn
,
50 $this->createFlatXMLDataSet(
51 dirname(__FILE__
) . '/queryDataset.xml'
55 $params = CRM_Contact_BAO_Query
::convertFormValues($fv);
56 $obj = new CRM_Contact_BAO_Query($params);
58 // let's set useGroupBy=true, to prevent duplicate records
59 $obj->_useGroupBy
= TRUE;
61 $dao = $obj->searchQuery();
64 while ($dao->fetch()) {
65 $contacts[] = $dao->contact_id
;
68 sort($contacts, SORT_NUMERIC
);
70 $this->assertEquals($ids, $contacts, 'In line ' . __LINE__
);