| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- // -----------------------------------------------------------------------
- // <copyright file="SelectorTests_Class.cs" company="Steven Kirk">
- // Copyright 2014 MIT Licence. See licence.md for more information.
- // </copyright>
- // -----------------------------------------------------------------------
- namespace Perspex.Styling.UnitTests
- {
- using System.Linq;
- using System.Reactive.Linq;
- using System.Threading.Tasks;
- using Moq;
- using Perspex.Styling;
- using Xunit;
- public class SelectorTests_Class
- {
- [Fact]
- public void Class_Selector_Should_Have_Correct_String_Representation()
- {
- var target = new Selector().Class("foo");
- Assert.Equal(".foo", target.ToString());
- }
- [Fact]
- public void PesudoClass_Selector_Should_Have_Correct_String_Representation()
- {
- var target = new Selector().Class(":foo");
- Assert.Equal(":foo", target.ToString());
- }
- [Fact]
- public async Task Class_Matches_Control_With_Class()
- {
- var control = new Control1
- {
- Classes = new Classes { "foo" },
- };
- var target = new Selector().Class("foo");
- var activator = target.Match(control).ObservableResult;
- Assert.True(await activator.Take(1));
- }
- [Fact]
- public async Task Class_Doesnt_Match_Control_Without_Class()
- {
- var control = new Control1
- {
- Classes = new Classes { "bar" },
- };
- var target = new Selector().Class("foo");
- var activator = target.Match(control).ObservableResult;
- Assert.False(await activator.Take(1));
- }
- [Fact]
- public async Task Class_Matches_Control_With_TemplatedParent()
- {
- var control = new Control1
- {
- Classes = new Classes { "foo" },
- TemplatedParent = new Mock<ITemplatedControl>().Object,
- };
- var target = new Selector().Class("foo");
- var activator = target.Match(control).ObservableResult;
- Assert.True(await activator.Take(1));
- }
- [Fact]
- public async Task Class_Tracks_Additions()
- {
- var control = new Control1();
- var target = new Selector().Class("foo");
- var activator = target.Match(control).ObservableResult;
- Assert.False(await activator.Take(1));
- control.Classes.Add("foo");
- Assert.True(await activator.Take(1));
- }
- [Fact]
- public async Task Class_Tracks_Removals()
- {
- var control = new Control1
- {
- Classes = new Classes { "foo" },
- };
- var target = new Selector().Class("foo");
- var activator = target.Match(control).ObservableResult;
- Assert.True(await activator.Take(1));
- control.Classes.Remove("foo");
- Assert.False(await activator.Take(1));
- }
- [Fact]
- public async Task Multiple_Classes()
- {
- var control = new Control1();
- var target = new Selector().Class("foo").Class("bar");
- var activator = target.Match(control).ObservableResult;
- Assert.False(await activator.Take(1));
- control.Classes.Add("foo");
- Assert.False(await activator.Take(1));
- control.Classes.Add("bar");
- Assert.True(await activator.Take(1));
- control.Classes.Remove("bar");
- Assert.False(await activator.Take(1));
- }
- public class Control1 : TestControlBase
- {
- }
- }
- }
|