Skip to content

Commit

Permalink
RNET-1155: Add more validation to .Filter arguments (#3620)
Browse files Browse the repository at this point in the history
* Add more validation to .Filter arguments

* Fix expected exception type
  • Loading branch information
nirinchev authored Jun 21, 2024
1 parent 35bb7b1 commit be05efc
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 4 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
### Fixed
* A `ForCurrentlyOutstandingWork` progress notifier would not immediately call its callback after registration. Instead you would have to wait for some data to be received to get your first update - if you were already caught up when you registered the notifier you could end up waiting a long time for the server to deliver a download that would call/expire your notifier. (Core 14.8.0)
* After compacting, a file upgrade would be triggered. This could cause loss of data if `ShouldDeleteIfMigrationNeeded` is set to `true`. (Issue [#3583](https://github.com/realm/realm-dotnet/issues/3583), Core 14.9.0)
* Passing in a deleted object as a substitution argument to `.Filter()` would throw a confusing error with a message starting with `invalid RQL for table`. It now throws a more descriptive error instead. (Issue [#3619](https://github.com/realm/realm-dotnet/issues/3619))

### Compatibility
* Realm Studio: 15.0.0 or later.
Expand Down
14 changes: 11 additions & 3 deletions Realm/Realm/DatabaseTypes/QueryArgument.cs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@
using System;
using System.Linq;
using MongoDB.Bson;
using Realms.Exceptions;
using Realms.Native;

namespace Realms
Expand Down Expand Up @@ -318,9 +317,18 @@ private QueryArgument(RealmValue? realmValue = null, GeoShapeBase? geoValue = nu
if (RealmValue != null)
{
var primitive = RealmValue.Value;
if (primitive.Type == RealmValueType.Object && !primitive.AsIRealmObject().IsManaged)
if (primitive.Type == RealmValueType.Object)
{
throw new RealmException("Can't use unmanaged object as argument of Filter");
var obj = primitive.AsIRealmObject();
if (!obj.IsManaged)
{
throw new ArgumentException("Can't use unmanaged object as argument of Filter");
}

if (!obj.IsValid)
{
throw new ArgumentException("Can't use removed object as argument of Filter");
}
}

var (primitiveValue, handles) = primitive.ToNative();
Expand Down
31 changes: 30 additions & 1 deletion Tests/Realm.Tests/Database/CollectionTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -1120,6 +1120,35 @@ public void Results_GetFiltered_SanityTest()
Assert.That(query.ToArray().All(i => i.Int >= 5));
}

[Test]
public void Results_Filter_WhenArgumentIsDeletedObject_Throws()
{
var targetObj = _realm.Write(() =>
{
var intPropertyObject = _realm.Add(new IntPropertyObject());

for (var i = 0; i < 10; i++)
{
_realm.Add(new ObjectWithObjectProperties
{
StandaloneObject = i % 2 == 0 ? intPropertyObject : null
});
}

return intPropertyObject;
});

var query = _realm.All<ObjectWithObjectProperties>().Filter($"{nameof(ObjectWithObjectProperties.StandaloneObject)} = $0", targetObj);
Assert.That(query.Count(), Is.EqualTo(5));

_realm.Write(() =>
{
_realm.Remove(targetObj);
});

Assert.Throws<ArgumentException>(() => _realm.All<ObjectWithObjectProperties>().Filter($"{nameof(ObjectWithObjectProperties.StandaloneObject)} = $0", targetObj));
}

public readonly struct StringQueryNumericData
{
public readonly string PropertyName;
Expand Down Expand Up @@ -1375,7 +1404,7 @@ public void QueryFilter_WithArgumentsUnmanagedObjects_ShouldThrow()
_realm.Add(new Owner { TopDog = new Dog { Name = "Doge", Color = "almost yellow", Vaccinated = true } });
});

Assert.Throws<RealmException>(() => _realm.All<Owner>().Filter("TopDog = $0", new Dog { Name = "Doge", Color = "almost yellow", Vaccinated = true }));
Assert.Throws<ArgumentException>(() => _realm.All<Owner>().Filter("TopDog = $0", new Dog { Name = "Doge", Color = "almost yellow", Vaccinated = true }));
}

[Test]
Expand Down

0 comments on commit be05efc

Please sign in to comment.