|
|
|
@ -1,6 +1,7 @@ |
|
|
|
using System; |
|
|
|
using System.Collections; |
|
|
|
using System.Collections.Generic; |
|
|
|
using System.Linq; |
|
|
|
using Avalonia.Controls; |
|
|
|
using Avalonia.Data; |
|
|
|
using Avalonia.Markup.Xaml.Data; |
|
|
|
@ -25,7 +26,7 @@ namespace Avalonia.Markup.Xaml.UnitTests.Data |
|
|
|
} |
|
|
|
|
|
|
|
[Fact] |
|
|
|
public void Validated_Property_Receives_BindingNotifications() |
|
|
|
public void Validated_Direct_Property_Receives_BindingNotifications() |
|
|
|
{ |
|
|
|
var source = new ValidationTestModel { MustBePositive = 5 }; |
|
|
|
var target = new TestControl |
|
|
|
@ -33,119 +34,25 @@ namespace Avalonia.Markup.Xaml.UnitTests.Data |
|
|
|
DataContext = source, |
|
|
|
}; |
|
|
|
|
|
|
|
target.Bind(TestControl.ValidatedProperty, new Binding(nameof(source.MustBePositive))); |
|
|
|
source.MustBePositive = 6; |
|
|
|
target.Bind( |
|
|
|
TestControl.ValidatedDirectProperty, |
|
|
|
new Binding(nameof(source.MustBePositive), BindingMode.TwoWay)); |
|
|
|
|
|
|
|
target.ValidatedDirect = 6; |
|
|
|
target.ValidatedDirect = -1; |
|
|
|
target.ValidatedDirect = 7; |
|
|
|
|
|
|
|
Assert.Equal( |
|
|
|
new[] |
|
|
|
{ |
|
|
|
new BindingNotification(5), |
|
|
|
new BindingNotification(new ArgumentOutOfRangeException("value"), BindingErrorType.DataValidationError), |
|
|
|
new BindingNotification(6), |
|
|
|
new BindingNotification(new ArgumentOutOfRangeException("value"), BindingErrorType.DataValidationError), |
|
|
|
new BindingNotification(7), |
|
|
|
}, |
|
|
|
target.Notifications); |
|
|
|
target.Notifications.AsEnumerable()); |
|
|
|
} |
|
|
|
|
|
|
|
//[Fact]
|
|
|
|
//public void Disabled_Validation_Should_Trigger_Validation_Change_On_Exception()
|
|
|
|
//{
|
|
|
|
// var source = new ValidationTestModel { MustBePositive = 5 };
|
|
|
|
// var target = new TestControl { DataContext = source };
|
|
|
|
// var binding = new Binding
|
|
|
|
// {
|
|
|
|
// Path = nameof(source.MustBePositive),
|
|
|
|
// Mode = BindingMode.TwoWay,
|
|
|
|
|
|
|
|
// // Even though EnableValidation = false, exception validation is enabled.
|
|
|
|
// EnableValidation = false,
|
|
|
|
// };
|
|
|
|
|
|
|
|
// target.Bind(TestControl.ValidationTestProperty, binding);
|
|
|
|
|
|
|
|
// target.ValidationTest = -5;
|
|
|
|
|
|
|
|
// Assert.True(false);
|
|
|
|
// //Assert.False(target.ValidationStatus.IsValid);
|
|
|
|
//}
|
|
|
|
|
|
|
|
//[Fact]
|
|
|
|
//public void Enabled_Validation_Should_Trigger_Validation_Change_On_Exception()
|
|
|
|
//{
|
|
|
|
// var source = new ValidationTestModel { MustBePositive = 5 };
|
|
|
|
// var target = new TestControl { DataContext = source };
|
|
|
|
// var binding = new Binding
|
|
|
|
// {
|
|
|
|
// Path = nameof(source.MustBePositive),
|
|
|
|
// Mode = BindingMode.TwoWay,
|
|
|
|
// EnableValidation = true,
|
|
|
|
// };
|
|
|
|
|
|
|
|
// target.Bind(TestControl.ValidationTestProperty, binding);
|
|
|
|
|
|
|
|
// target.ValidationTest = -5;
|
|
|
|
// Assert.True(false);
|
|
|
|
// //Assert.False(target.ValidationStatus.IsValid);
|
|
|
|
//}
|
|
|
|
|
|
|
|
|
|
|
|
//[Fact]
|
|
|
|
//public void Passed_Validation_Should_Not_Add_Invalid_Pseudo_Class()
|
|
|
|
//{
|
|
|
|
// var control = new TestControl();
|
|
|
|
// var model = new ValidationTestModel { MustBePositive = 1 };
|
|
|
|
// var binding = new Binding
|
|
|
|
// {
|
|
|
|
// Path = nameof(model.MustBePositive),
|
|
|
|
// Mode = BindingMode.TwoWay,
|
|
|
|
// EnableValidation = true,
|
|
|
|
// };
|
|
|
|
|
|
|
|
// control.Bind(TestControl.ValidationTestProperty, binding);
|
|
|
|
// control.DataContext = model;
|
|
|
|
// Assert.DoesNotContain(control.Classes, x => x == ":invalid");
|
|
|
|
//}
|
|
|
|
|
|
|
|
//[Fact]
|
|
|
|
//public void Failed_Validation_Should_Add_Invalid_Pseudo_Class()
|
|
|
|
//{
|
|
|
|
// var control = new TestControl();
|
|
|
|
// var model = new ValidationTestModel { MustBePositive = 1 };
|
|
|
|
// var binding = new Binding
|
|
|
|
// {
|
|
|
|
// Path = nameof(model.MustBePositive),
|
|
|
|
// Mode = BindingMode.TwoWay,
|
|
|
|
// EnableValidation = true,
|
|
|
|
// };
|
|
|
|
|
|
|
|
// control.Bind(TestControl.ValidationTestProperty, binding);
|
|
|
|
// control.DataContext = model;
|
|
|
|
// control.ValidationTest = -5;
|
|
|
|
// Assert.Contains(control.Classes, x => x == ":invalid");
|
|
|
|
//}
|
|
|
|
|
|
|
|
//[Fact]
|
|
|
|
//public void Failed_Then_Passed_Validation_Should_Remove_Invalid_Pseudo_Class()
|
|
|
|
//{
|
|
|
|
// var control = new TestControl();
|
|
|
|
// var model = new ValidationTestModel { MustBePositive = 1 };
|
|
|
|
|
|
|
|
// var binding = new Binding
|
|
|
|
// {
|
|
|
|
// Path = nameof(model.MustBePositive),
|
|
|
|
// Mode = BindingMode.TwoWay,
|
|
|
|
// EnableValidation = true,
|
|
|
|
// };
|
|
|
|
|
|
|
|
// control.Bind(TestControl.ValidationTestProperty, binding);
|
|
|
|
// control.DataContext = model;
|
|
|
|
|
|
|
|
|
|
|
|
// control.ValidationTest = -5;
|
|
|
|
// Assert.Contains(control.Classes, x => x == ":invalid");
|
|
|
|
// control.ValidationTest = 5;
|
|
|
|
// Assert.DoesNotContain(control.Classes, x => x == ":invalid");
|
|
|
|
//}
|
|
|
|
|
|
|
|
private class TestControl : Control |
|
|
|
{ |
|
|
|
public static readonly StyledProperty<int> NonValidatedProperty = |
|
|
|
@ -158,6 +65,15 @@ namespace Avalonia.Markup.Xaml.UnitTests.Data |
|
|
|
nameof(Validated), |
|
|
|
enableDataValidation: true); |
|
|
|
|
|
|
|
public static readonly DirectProperty<TestControl, int> ValidatedDirectProperty = |
|
|
|
AvaloniaProperty.RegisterDirect<TestControl, int>( |
|
|
|
nameof(Validated), |
|
|
|
o => o.ValidatedDirect, |
|
|
|
(o, v) => o.ValidatedDirect = v, |
|
|
|
enableDataValidation: true); |
|
|
|
|
|
|
|
private int _direct; |
|
|
|
|
|
|
|
public int NonValidated |
|
|
|
{ |
|
|
|
get { return GetValue(NonValidatedProperty); } |
|
|
|
@ -170,6 +86,12 @@ namespace Avalonia.Markup.Xaml.UnitTests.Data |
|
|
|
set { SetValue(ValidatedProperty, value); } |
|
|
|
} |
|
|
|
|
|
|
|
public int ValidatedDirect |
|
|
|
{ |
|
|
|
get { return _direct; } |
|
|
|
set { SetAndRaise(ValidatedDirectProperty, ref _direct, value); } |
|
|
|
} |
|
|
|
|
|
|
|
public IList<BindingNotification> Notifications { get; } = new List<BindingNotification>(); |
|
|
|
|
|
|
|
protected override void BindingNotificationReceived(AvaloniaProperty property, BindingNotification notification) |
|
|
|
@ -180,11 +102,11 @@ namespace Avalonia.Markup.Xaml.UnitTests.Data |
|
|
|
|
|
|
|
private class ValidationTestModel : NotifyingBase |
|
|
|
{ |
|
|
|
private int mustBePositive; |
|
|
|
private int _mustBePositive; |
|
|
|
|
|
|
|
public int MustBePositive |
|
|
|
{ |
|
|
|
get { return mustBePositive; } |
|
|
|
get { return _mustBePositive; } |
|
|
|
set |
|
|
|
{ |
|
|
|
if (value <= 0) |
|
|
|
@ -192,8 +114,11 @@ namespace Avalonia.Markup.Xaml.UnitTests.Data |
|
|
|
throw new ArgumentOutOfRangeException(nameof(value)); |
|
|
|
} |
|
|
|
|
|
|
|
mustBePositive = value; |
|
|
|
RaisePropertyChanged(); |
|
|
|
if (_mustBePositive != value) |
|
|
|
{ |
|
|
|
_mustBePositive = value; |
|
|
|
RaisePropertyChanged(); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|