Skip to content

Commit 47f26e6

Browse files
committed
Swift: fix codegen unit tests
1 parent 10976bb commit 47f26e6

File tree

4 files changed

+39
-37
lines changed

4 files changed

+39
-37
lines changed

swift/codegen/generators/qlgen.py

Lines changed: 10 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -218,18 +218,19 @@ def generate(opts, renderer):
218218
existing |= {q for q in test_out.rglob(missing_test_source_filename)}
219219

220220
data = schema.load(input)
221-
inheritance_graph = {name: cls.bases for name, cls in data.classes.items()}
222-
input_classes = [data.classes[name] for name in toposort_flatten(inheritance_graph)]
223221

224-
classes = [get_ql_class(cls, data.classes) for cls in input_classes]
222+
classes = {name: get_ql_class(cls, data.classes) for name, cls in data.classes.items()}
225223
imports = {}
226224

227-
renderer.render(ql.DbClasses(cls for cls in classes if not cls.ipa), out / "Db.qll")
225+
inheritance_graph = {name: cls.bases for name, cls in data.classes.items()}
226+
db_classes = [classes[name] for name in toposort_flatten(inheritance_graph) if not classes[name].ipa]
227+
renderer.render(ql.DbClasses(db_classes), out / "Db.qll")
228228

229-
for c in classes:
229+
classes_by_dir_and_name = sorted(classes.values(), key=lambda cls: (cls.dir, cls.name))
230+
for c in classes_by_dir_and_name:
230231
imports[c.name] = get_import(stub_out / c.path, opts.swift_dir)
231232

232-
for c in classes:
233+
for c in classes.values():
233234
qll = out / c.path.with_suffix(".qll")
234235
c.imports = [imports[t] for t in get_classes_used_by(c)]
235236
renderer.render(c, qll)
@@ -243,10 +244,9 @@ def generate(opts, renderer):
243244
include_file = stub_out.with_suffix(".qll")
244245
renderer.render(ql.ImportList(list(imports.values())), include_file)
245246

246-
renderer.render(ql.GetParentImplementation(
247-
classes), out / 'GetImmediateParent.qll')
247+
renderer.render(ql.GetParentImplementation(classes_by_dir_and_name), out / 'GetImmediateParent.qll')
248248

249-
for c in input_classes:
249+
for c in data.classes.values():
250250
if _should_skip_qltest(c, data.classes):
251251
continue
252252
test_dir = test_out / c.dir / c.name
@@ -267,7 +267,7 @@ def generate(opts, renderer):
267267
final_ipa_types = []
268268
non_final_ipa_types = []
269269
constructor_imports = []
270-
for cls in input_classes:
270+
for cls in sorted(data.classes.values(), key=lambda cls: (cls.dir, cls.name)):
271271
ipa_type = get_ql_ipa_class(cls)
272272
if ipa_type.is_final:
273273
final_ipa_types.append(ipa_type)

swift/codegen/lib/ql.py

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -79,7 +79,7 @@ class Class:
7979
qltest_skip: bool = False
8080
qltest_collapse_hierarchy: bool = False
8181
qltest_uncollapse_hierarchy: bool = False
82-
has_db_id: bool = False
82+
has_db_id: bool = True
8383
ipa: bool = False
8484

8585
def __post_init__(self):

swift/codegen/test/test_ql.py

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,7 @@ def test_property_has_first_table_param_marked():
2121
])
2222
def test_property_is_a_class(type, expected):
2323
tableparams = ["a", "result", "b"]
24-
expected_tableparams = ["a", "x" if expected else "result", "b"]
24+
expected_tableparams = ["a", "result" if expected else "result", "b"]
2525
prop = ql.Property("Prop", type, tableparams=tableparams)
2626
assert prop.type_is_class is expected
2727
assert [p.param for p in prop.tableparams] == expected_tableparams
@@ -46,7 +46,7 @@ def test_property_indefinite_article(name, expected_getter):
4646
("X", True),
4747
])
4848
def test_property_is_repeated(plural, expected):
49-
prop = ql.Property("foo", "Foo", "props", ["x"], plural=plural)
49+
prop = ql.Property("foo", "Foo", "props", ["result"], plural=plural)
5050
assert prop.is_repeated is expected
5151

5252

@@ -58,12 +58,12 @@ def test_property_is_repeated(plural, expected):
5858
(False, True, None, False),
5959
])
6060
def test_property_is_single(is_optional, is_predicate, plural, expected):
61-
prop = ql.Property("foo", "Foo", "props", ["x"], plural=plural, is_predicate=is_predicate, is_optional=is_optional)
61+
prop = ql.Property("foo", "Foo", "props", ["result"], plural=plural, is_predicate=is_predicate, is_optional=is_optional)
6262
assert prop.is_single is expected
6363

6464

6565
def test_property_no_plural_no_indefinite_getter():
66-
prop = ql.Property("Prop", "Foo", "props", ["x"])
66+
prop = ql.Property("Prop", "Foo", "props", ["result"])
6767
assert prop.indefinite_getter is None
6868

6969

swift/codegen/test/test_qlgen.py

Lines changed: 24 additions & 22 deletions
Original file line numberDiff line numberDiff line change
@@ -101,7 +101,7 @@ def _filter_generated_classes(ret, output_test_files=False):
101101
str(f): ret[ql_test_output_path() / f]
102102
for f in test_files
103103
}
104-
base_files -= {pathlib.Path("IpaTypes.qll"), pathlib.Path("IpaConstructors.qll")}
104+
base_files -= {pathlib.Path(f"{name}.qll") for name in ("Db", "IpaTypes", "IpaConstructors")}
105105
assert stub_files == base_files
106106
return {
107107
str(f): (ret[stub_path() / f], ret[ql_output_path() / f])
@@ -131,6 +131,8 @@ def test_empty(generate):
131131
children_file(): ql.GetParentImplementation(),
132132
ql_output_path() / "IpaTypes.qll": ql.Ipa.Types(schema.root_class_name),
133133
ql_output_path() / "IpaConstructors.qll": ql.ImportList(),
134+
ql_output_path() / "Db.qll": ql.DbClasses(),
135+
ql_output_path() / "Db.qll": ql.DbClasses(),
134136
}
135137

136138

@@ -139,7 +141,7 @@ def test_one_empty_class(generate_classes):
139141
schema.Class("A")
140142
]) == {
141143
"A.qll": (ql.Stub(name="A", base_import=gen_import_prefix + "A"),
142-
ql.Class(name="A", final=True, fields=[ql.Field('id', type='@a')])),
144+
ql.Class(name="A", final=True)),
143145
}
144146

145147

@@ -157,7 +159,7 @@ def test_hierarchy(generate_classes):
157159
"C.qll": (ql.Stub(name="C", base_import=gen_import_prefix + "C"),
158160
ql.Class(name="C", bases=["A"], imports=[stub_import_prefix + "A"])),
159161
"D.qll": (ql.Stub(name="D", base_import=gen_import_prefix + "D"),
160-
ql.Class(name="D", final=True, bases=["B", "C"], fields=[ql.Field("id", type="@d")],
162+
ql.Class(name="D", final=True, bases=["B", "C"],
161163
imports=[stub_import_prefix + cls for cls in "BC"])),
162164
}
163165

@@ -183,7 +185,7 @@ def test_hierarchy_children(generate_children_implementations):
183185
stub_import_prefix + "A"]),
184186
ql.Class(name="C", bases=["A"], imports=[
185187
stub_import_prefix + "A"]),
186-
ql.Class(name="D", final=True, bases=["B", "C"], fields=[ql.Field("id", type="@d")],
188+
ql.Class(name="D", final=True, bases=["B", "C"],
187189
imports=[stub_import_prefix + cls for cls in "BC"]),
188190
],
189191
)
@@ -195,10 +197,10 @@ def test_single_property(generate_classes):
195197
schema.SingleProperty("foo", "bar")]),
196198
]) == {
197199
"MyObject.qll": (ql.Stub(name="MyObject", base_import=gen_import_prefix + "MyObject"),
198-
ql.Class(name="MyObject", final=True, fields=[ql.Field("id", type="@my_object")],
200+
ql.Class(name="MyObject", final=True,
199201
properties=[
200202
ql.Property(singular="Foo", type="bar", tablename="my_objects",
201-
tableparams=["id", "result"]),
203+
tableparams=["this", "result"]),
202204
])),
203205
}
204206

@@ -212,14 +214,14 @@ def test_single_properties(generate_classes):
212214
]),
213215
]) == {
214216
"MyObject.qll": (ql.Stub(name="MyObject", base_import=gen_import_prefix + "MyObject"),
215-
ql.Class(name="MyObject", final=True, fields=[ql.Field("id", type="@my_object")],
217+
ql.Class(name="MyObject", final=True,
216218
properties=[
217219
ql.Property(singular="One", type="x", tablename="my_objects",
218-
tableparams=["id", "result", "_", "_"]),
220+
tableparams=["this", "result", "_", "_"]),
219221
ql.Property(singular="Two", type="y", tablename="my_objects",
220-
tableparams=["id", "_", "result", "_"]),
222+
tableparams=["this", "_", "result", "_"]),
221223
ql.Property(singular="Three", type="z", tablename="my_objects",
222-
tableparams=["id", "_", "_", "result"]),
224+
tableparams=["this", "_", "_", "result"]),
223225
])),
224226
}
225227

@@ -231,9 +233,9 @@ def test_optional_property(generate_classes, is_child):
231233
schema.OptionalProperty("foo", "bar", is_child=is_child)]),
232234
]) == {
233235
"MyObject.qll": (ql.Stub(name="MyObject", base_import=gen_import_prefix + "MyObject"),
234-
ql.Class(name="MyObject", final=True, fields=[ql.Field("id", type="@my_object")], properties=[
236+
ql.Class(name="MyObject", final=True, properties=[
235237
ql.Property(singular="Foo", type="bar", tablename="my_object_foos",
236-
tableparams=["id", "result"],
238+
tableparams=["this", "result"],
237239
is_optional=True, is_child=is_child),
238240
])),
239241
}
@@ -246,9 +248,9 @@ def test_repeated_property(generate_classes, is_child):
246248
schema.RepeatedProperty("foo", "bar", is_child=is_child)]),
247249
]) == {
248250
"MyObject.qll": (ql.Stub(name="MyObject", base_import=gen_import_prefix + "MyObject"),
249-
ql.Class(name="MyObject", final=True, fields=[ql.Field("id", type="@my_object")], properties=[
251+
ql.Class(name="MyObject", final=True, properties=[
250252
ql.Property(singular="Foo", plural="Foos", type="bar", tablename="my_object_foos",
251-
tableparams=["id", "index", "result"], is_child=is_child),
253+
tableparams=["this", "index", "result"], is_child=is_child),
252254
])),
253255
}
254256

@@ -260,9 +262,9 @@ def test_repeated_optional_property(generate_classes, is_child):
260262
schema.RepeatedOptionalProperty("foo", "bar", is_child=is_child)]),
261263
]) == {
262264
"MyObject.qll": (ql.Stub(name="MyObject", base_import=gen_import_prefix + "MyObject"),
263-
ql.Class(name="MyObject", final=True, fields=[ql.Field("id", type="@my_object")], properties=[
265+
ql.Class(name="MyObject", final=True, properties=[
264266
ql.Property(singular="Foo", plural="Foos", type="bar", tablename="my_object_foos",
265-
tableparams=["id", "index", "result"], is_optional=True,
267+
tableparams=["this", "index", "result"], is_optional=True,
266268
is_child=is_child),
267269
])),
268270
}
@@ -274,9 +276,9 @@ def test_predicate_property(generate_classes):
274276
schema.PredicateProperty("is_foo")]),
275277
]) == {
276278
"MyObject.qll": (ql.Stub(name="MyObject", base_import=gen_import_prefix + "MyObject"),
277-
ql.Class(name="MyObject", final=True, fields=[ql.Field("id", type="@my_object")], properties=[
279+
ql.Class(name="MyObject", final=True, properties=[
278280
ql.Property(singular="isFoo", type="predicate", tablename="my_object_is_foo",
279-
tableparams=["id"],
281+
tableparams=["this"],
280282
is_predicate=True),
281283
])),
282284
}
@@ -291,15 +293,15 @@ def test_single_class_property(generate_classes, is_child):
291293
]) == {
292294
"MyObject.qll": (ql.Stub(name="MyObject", base_import=gen_import_prefix + "MyObject"),
293295
ql.Class(
294-
name="MyObject", final=True, fields=[ql.Field("id", type="@my_object")], imports=[stub_import_prefix + "Bar"], properties=[
296+
name="MyObject", final=True, imports=[stub_import_prefix + "Bar"], properties=[
295297
ql.Property(singular="Foo", type="Bar", tablename="my_objects",
296298
tableparams=[
297-
"id", "result"],
299+
"this", "result"],
298300
is_child=is_child),
299301
],
300302
)),
301303
"Bar.qll": (ql.Stub(name="Bar", base_import=gen_import_prefix + "Bar"),
302-
ql.Class(name="Bar", final=True, fields=[ql.Field("id", type="@bar")])),
304+
ql.Class(name="Bar", final=True)),
303305
}
304306

305307

@@ -312,7 +314,7 @@ def test_class_dir(generate_classes):
312314
f"{dir}/A.qll": (ql.Stub(name="A", base_import=gen_import_prefix + "another.rel.path.A"),
313315
ql.Class(name="A", dir=dir)),
314316
"B.qll": (ql.Stub(name="B", base_import=gen_import_prefix + "B"),
315-
ql.Class(name="B", final=True, fields=[ql.Field("id", type="@b")], bases=["A"],
317+
ql.Class(name="B", final=True, bases=["A"],
316318
imports=[stub_import_prefix + "another.rel.path.A"])),
317319
}
318320

0 commit comments

Comments
 (0)