From a7479e58c14f02cc152014dfaf538ee377863d6a Mon Sep 17 00:00:00 2001 From: Kenneth Geisshirt Date: Thu, 11 Jul 2024 13:07:45 +0200 Subject: [PATCH] Allow both internal and public name in realm::Results::{sort, distinct} (#7877) --- CHANGELOG.md | 3 +-- src/realm/object-store/results.cpp | 3 +++ test/object-store/results.cpp | 27 +++++++++++++++++++++++++-- 3 files changed, 29 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 37269ebe229..6c0032ba6e1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,8 +5,7 @@ * None. ### Fixed -* ([#????](https://github.com/realm/realm-core/issues/????), since v?.?.?) -* None. +* When a public name is defined on a property, calling `realm::Results::sort()` or `realm::Results::distinct()` with the internal name could throw an error like `Cannot sort on key path 'NAME': property 'PersonObject.NAME' does not exist`. ([realm/realm-js#6779](https://github.com/realm/realm-js/issues/6779), since v12.12.0) ### Breaking changes * None. diff --git a/src/realm/object-store/results.cpp b/src/realm/object-store/results.cpp index e9584d2b410..8d959ae05a7 100644 --- a/src/realm/object-store/results.cpp +++ b/src/realm/object-store/results.cpp @@ -871,6 +871,9 @@ static std::vector parse_keypath(StringData keypath, Schema c begin = sep + (sep != end); auto prop = object_schema->property_for_public_name(key); + if (!prop) { + prop = object_schema->property_for_name(key); + } check(prop, "property '%1.%2' does not exist", object_schema->name, key); if (is_dictionary(prop->type)) { check(index.length(), "missing dictionary key"); diff --git a/test/object-store/results.cpp b/test/object-store/results.cpp index 4b3c6a9cb08..1814d06cd87 100644 --- a/test/object-store/results.cpp +++ b/test/object-store/results.cpp @@ -4984,7 +4984,7 @@ TEST_CASE("results: public name declared", "[results]") { realm->commit_transaction(); Results r(realm, table); - SECTION("sorted") { + SECTION("sorted by public_name") { auto sorted = r.sort({{"public_value", true}}); REQUIRE(sorted.limit(0).size() == 0); REQUIRE_ORDER(sorted.limit(1), 2); @@ -4993,7 +4993,16 @@ TEST_CASE("results: public name declared", "[results]") { REQUIRE_ORDER(sorted.limit(100), 2, 6, 3, 7, 0, 4, 1, 5); } - SECTION("distinct") { + SECTION("sorted by name") { + auto sorted = r.sort({{"value", true}}); + REQUIRE(sorted.limit(0).size() == 0); + REQUIRE_ORDER(sorted.limit(1), 2); + REQUIRE_ORDER(sorted.limit(2), 2, 6); + REQUIRE_ORDER(sorted.limit(8), 2, 6, 3, 7, 0, 4, 1, 5); + REQUIRE_ORDER(sorted.limit(100), 2, 6, 3, 7, 0, 4, 1, 5); + } + + SECTION("distinct by public_name") { auto sorted = r.distinct({"public_value"}); REQUIRE(sorted.limit(0).size() == 0); REQUIRE_ORDER(sorted.limit(1), 0); @@ -5006,6 +5015,20 @@ TEST_CASE("results: public name declared", "[results]") { REQUIRE_ORDER(sorted.limit(2), 2, 3); REQUIRE_ORDER(sorted.limit(8), 2, 3, 0, 1); } + + SECTION("distinct by name") { + auto sorted = r.distinct({"value"}); + REQUIRE(sorted.limit(0).size() == 0); + REQUIRE_ORDER(sorted.limit(1), 0); + REQUIRE_ORDER(sorted.limit(2), 0, 1); + REQUIRE_ORDER(sorted.limit(8), 0, 1, 2, 3); + + sorted = r.sort({{"value", true}}).distinct({"value"}); + REQUIRE(sorted.limit(0).size() == 0); + REQUIRE_ORDER(sorted.limit(1), 2); + REQUIRE_ORDER(sorted.limit(2), 2, 3); + REQUIRE_ORDER(sorted.limit(8), 2, 3, 0, 1); + } } TEST_CASE("notifications: objects with PK recreated", "[results]") {