3 namespace api\v
4\Action
;
6 use Civi\Api4\CustomField
;
7 use Civi\Api4\CustomGroup
;
8 use api\v
4\Traits\QueryCounterTrait
;
13 class CustomValuePerformanceTest
extends BaseCustomValueTest
{
15 use QueryCounterTrait
;
17 public function testQueryCount() {
19 $this->markTestIncomplete();
21 $customGroupId = CustomGroup
::create()
22 ->setCheckPermissions(FALSE)
23 ->addValue('name', 'MyContactFields')
24 ->addValue('title', 'MyContactFields')
25 ->addValue('extends', 'Contact')
30 ->setCheckPermissions(FALSE)
31 ->addValue('label', 'FavColor')
32 ->addValue('custom_group_id', $customGroupId)
33 ->addValue('options', ['r' => 'Red', 'g' => 'Green', 'b' => 'Blue'])
34 ->addValue('html_type', 'Select')
35 ->addValue('data_type', 'String')
39 ->setCheckPermissions(FALSE)
40 ->addValue('label', 'FavAnimal')
41 ->addValue('custom_group_id', $customGroupId)
42 ->addValue('html_type', 'Text')
43 ->addValue('data_type', 'String')
47 ->setCheckPermissions(FALSE)
48 ->addValue('label', 'FavLetter')
49 ->addValue('custom_group_id', $customGroupId)
50 ->addValue('html_type', 'Text')
51 ->addValue('data_type', 'String')
55 ->setCheckPermissions(FALSE)
56 ->addValue('label', 'FavFood')
57 ->addValue('custom_group_id', $customGroupId)
58 ->addValue('html_type', 'Text')
59 ->addValue('data_type', 'String')
62 $this->beginQueryCount();
65 ->setCheckPermissions(FALSE)
66 ->addValue('first_name', 'Red')
67 ->addValue('last_name', 'Tester')
68 ->addValue('contact_type', 'Individual')
69 ->addValue('MyContactFields.FavColor', 'r')
70 ->addValue('MyContactFields.FavAnimal', 'Sheep')
71 ->addValue('MyContactFields.FavLetter', 'z')
72 ->addValue('MyContactFields.FavFood', 'Coconuts')
76 ->setCheckPermissions(FALSE)
77 ->addSelect('display_name')
78 ->addSelect('MyContactFields.FavColor.label')
79 ->addSelect('MyContactFields.FavColor.weight')
80 ->addSelect('MyContactFields.FavColor.is_default')
81 ->addSelect('MyContactFields.FavAnimal')
82 ->addSelect('MyContactFields.FavLetter')
83 ->addWhere('MyContactFields.FavColor', '=', 'r')
84 ->addWhere('MyContactFields.FavFood', '=', 'Coconuts')
85 ->addWhere('MyContactFields.FavAnimal', '=', 'Sheep')
86 ->addWhere('MyContactFields.FavLetter', '=', 'z')
90 // FIXME: This count is artificially high due to the line
91 // $this->entity = Tables::getBriefName(Tables::getClassForTable($targetTable));
92 // In class Joinable. TODO: Investigate why.