Browse Source

add test for casting after indexer

pull/5038/head
Andrey Kunchev 5 years ago
parent
commit
bf2dfff8f6
  1. 37
      tests/Avalonia.Markup.Xaml.UnitTests/MarkupExtensions/CompiledBindingExtensionTests.cs

37
tests/Avalonia.Markup.Xaml.UnitTests/MarkupExtensions/CompiledBindingExtensionTests.cs

@ -759,6 +759,36 @@ namespace Avalonia.Markup.Xaml.UnitTests.MarkupExtensions
}
}
[Fact]
public void SupportCastToTypeInExpressionWithPropertyIndexer()
{
using (UnitTestApplication.Start(TestServices.StyledWindow))
{
var xaml = @"
<Window xmlns='https://github.com/avaloniaui'
xmlns:x='http://schemas.microsoft.com/winfx/2006/xaml'
xmlns:local='using:Avalonia.Markup.Xaml.UnitTests.MarkupExtensions'
x:DataType='local:TestDataContext'>
<ContentControl Content='{CompiledBinding ((local:TestData)ObjectsArrayProperty[0]).StringProperty}' Name='contentControl' />
</Window>";
var window = (Window)AvaloniaRuntimeXamlLoader.Load(xaml);
var contentControl = window.FindControl<ContentControl>("contentControl");
var data = new TestData()
{
StringProperty = "Foo"
};
var dataContext = new TestDataContext
{
ObjectsArrayProperty = new object[] { data }
};
window.DataContext = dataContext;
Assert.Equal(data.StringProperty, contentControl.Content);
}
}
[Fact]
public void SupportCastToTypeInExpressionWithProperty_DifferentTypeEvaluatesToNull()
{
@ -818,6 +848,11 @@ namespace Avalonia.Markup.Xaml.UnitTests.MarkupExtensions
}
public class TestData
{
public string StringProperty { get; set; }
}
public class TestDataContext : IHasPropertyDerived
{
public string StringProperty { get; set; }
@ -830,6 +865,8 @@ namespace Avalonia.Markup.Xaml.UnitTests.MarkupExtensions
public string[] ArrayProperty { get; set; }
public object[] ObjectsArrayProperty { get; set; }
public List<string> ListProperty { get; set; } = new List<string>();
public NonIntegerIndexer NonIntegerIndexerProperty { get; set; } = new NonIntegerIndexer();

Loading…
Cancel
Save