52 {
56
59 .
id = 0, .label =
"root", .child_count = 0, .flags2 = &flags};
63
64 AtkObject* root_object =
65 atk_object_ref_accessible_child(ATK_OBJECT(accessible), 0);
66 EXPECT_EQ(atk_object_get_n_accessible_children(root_object), 0);
67
68
69 AtkObject* child1_object = nullptr;
71 .
id = 111, .label =
"child 1", .flags2 = &flags};
72 {
74 root_object, "children-changed::add");
75 EXPECT_SIGNAL2(child1_added, ::testing::Eq(0), ::testing::A<AtkObject*>())
76 .WillOnce(::testing::SaveArg<1>(&child1_object));
77
78 int32_t children[] = {111};
84 }
85
86 EXPECT_EQ(atk_object_get_n_accessible_children(root_object), 1);
87 EXPECT_EQ(atk_object_ref_accessible_child(root_object, 0), child1_object);
88
89 EXPECT_STREQ(atk_object_get_name(child1_object), "child 1");
90 EXPECT_EQ(atk_object_get_parent(child1_object), root_object);
91 EXPECT_EQ(atk_object_get_index_in_parent(child1_object), 0);
92 EXPECT_EQ(atk_object_get_n_accessible_children(child1_object), 0);
93
94
95 AtkObject* child2_object = nullptr;
97 .
id = 222, .label =
"child 2", .flags2 = &flags};
98 {
100 root_object, "children-changed::add");
101 EXPECT_SIGNAL2(child2_added, ::testing::Eq(1), ::testing::A<AtkObject*>())
102 .WillOnce(::testing::SaveArg<1>(&child2_object));
103
104 int32_t children[] = {111, 222};
110 }
111
112 EXPECT_EQ(atk_object_get_n_accessible_children(root_object), 2);
113 EXPECT_EQ(atk_object_ref_accessible_child(root_object, 0), child1_object);
114 EXPECT_EQ(atk_object_ref_accessible_child(root_object, 1), child2_object);
115
116 EXPECT_STREQ(atk_object_get_name(child1_object), "child 1");
117 EXPECT_EQ(atk_object_get_parent(child1_object), root_object);
118 EXPECT_EQ(atk_object_get_index_in_parent(child1_object), 0);
119 EXPECT_EQ(atk_object_get_n_accessible_children(child1_object), 0);
120
121 EXPECT_STREQ(atk_object_get_name(child2_object), "child 2");
122 EXPECT_EQ(atk_object_get_parent(child2_object), root_object);
123 EXPECT_EQ(atk_object_get_index_in_parent(child2_object), 1);
124 EXPECT_EQ(atk_object_get_n_accessible_children(child2_object), 0);
125
126
127 {
129 root_object, "children-changed::remove");
131 ::testing::Eq(child1_object));
132
133 const int32_t children[] = {222};
139 }
140
141 EXPECT_EQ(atk_object_get_n_accessible_children(root_object), 1);
142 EXPECT_EQ(atk_object_ref_accessible_child(root_object, 0), child2_object);
143
144 EXPECT_STREQ(atk_object_get_name(child2_object), "child 2");
145 EXPECT_EQ(atk_object_get_parent(child2_object), root_object);
146 EXPECT_EQ(atk_object_get_index_in_parent(child2_object), 0);
147 EXPECT_EQ(atk_object_get_n_accessible_children(child2_object), 0);
148
149
150 {
152 root_object, "children-changed::remove");
154 ::testing::Eq(child2_object));
155
160 }
161
162 EXPECT_EQ(atk_object_get_n_accessible_children(root_object), 0);
163}
g_autoptr(GMutexLocker) locker
G_MODULE_EXPORT FlDartProject * fl_dart_project_new()
G_MODULE_EXPORT FlEngine * fl_engine_new(FlDartProject *project)
FlViewAccessible * fl_view_accessible_new(FlEngine *engine, FlutterViewId view_id)
void fl_view_accessible_handle_update_semantics(FlViewAccessible *self, const FlutterSemanticsUpdate2 *update)
#define EXPECT_SIGNAL2(mock, a1, a2)
const int32_t * children_in_traversal_order
Array of child node IDs in traversal order. Has length child_count.
int32_t id
The unique identifier for this node.
size_t child_count
The number of children this node has.
A batch of updates to semantics nodes and custom actions.
size_t node_count
The number of semantics node updates.