The tests are pasing. The UI is working. The tests sometimes hang.
This commit is contained in:
@@ -9,9 +9,9 @@ namespace WpfViewModelFirst.Tests
|
|||||||
[Fact]
|
[Fact]
|
||||||
public void Part1WillSetPart1ViewModelToCurrentViewModel()
|
public void Part1WillSetPart1ViewModelToCurrentViewModel()
|
||||||
{
|
{
|
||||||
Part1ViewModel part1ViewModel = new(() => { });
|
Part1ViewModel part1ViewModel = new(() => { return Task.CompletedTask; });
|
||||||
Mock<IViewModelFactory> mockViewModelFactory = new Mock<IViewModelFactory>();
|
Mock<IViewModelFactory> mockViewModelFactory = new Mock<IViewModelFactory>();
|
||||||
mockViewModelFactory.Setup(vmf => vmf.GetPart1ViewModel(It.IsAny<Action>()))
|
mockViewModelFactory.Setup(vmf => vmf.GetPart1ViewModel(It.IsAny<Func<Task>>()))
|
||||||
.Returns(part1ViewModel);
|
.Returns(part1ViewModel);
|
||||||
MainWindowViewModel main = new(mockViewModelFactory.Object);
|
MainWindowViewModel main = new(mockViewModelFactory.Object);
|
||||||
main.Part1(null);
|
main.Part1(null);
|
||||||
@@ -22,19 +22,21 @@ namespace WpfViewModelFirst.Tests
|
|||||||
{
|
{
|
||||||
TaskCompletionSource<bool> taskCompletionSource = new TaskCompletionSource<bool>();
|
TaskCompletionSource<bool> taskCompletionSource = new TaskCompletionSource<bool>();
|
||||||
Mock<IViewModelFactory> mockViewModelFactory = new Mock<IViewModelFactory>();
|
Mock<IViewModelFactory> mockViewModelFactory = new Mock<IViewModelFactory>();
|
||||||
mockViewModelFactory.Setup(vmf => vmf.GetPart1ViewModel(It.IsAny<Action>()))
|
mockViewModelFactory.Setup(vmf => vmf.GetPart1ViewModel(It.IsAny<Func<Task>>()))
|
||||||
|
|
||||||
.Returns(() => new Part1ViewModel(() =>
|
.Returns(() => new Part1ViewModel(() =>
|
||||||
{
|
{
|
||||||
//taskCompletionSource.SetResult(true);
|
return Task.CompletedTask;
|
||||||
|
|
||||||
}))
|
}))
|
||||||
.Callback<Action>(c =>
|
.Callback<Func<Task>>(c =>
|
||||||
{
|
{
|
||||||
//taskCompletionSource.SetResult(true);
|
//taskCompletionSource.SetResult(true);
|
||||||
|
Task.Run(() =>
|
||||||
|
{
|
||||||
c.Invoke();
|
c.Invoke();
|
||||||
})
|
});
|
||||||
;
|
});
|
||||||
mockViewModelFactory.Setup(vmf => vmf.GetPart2ViewModel())
|
mockViewModelFactory.Setup(vmf => vmf.GetPart2ViewModel())
|
||||||
.Returns(() => new Part2ViewModel());
|
.Returns(() => new Part2ViewModel());
|
||||||
MainWindowViewModel main = new(mockViewModelFactory.Object);
|
MainWindowViewModel main = new(mockViewModelFactory.Object);
|
||||||
@@ -42,6 +44,10 @@ namespace WpfViewModelFirst.Tests
|
|||||||
main.Part1(null);
|
main.Part1(null);
|
||||||
await taskCompletionSource.Task.WaitAsync(CancellationToken.None);
|
await taskCompletionSource.Task.WaitAsync(CancellationToken.None);
|
||||||
Assert.IsType<Part2ViewModel>(main.CurrentViewModel);
|
Assert.IsType<Part2ViewModel>(main.CurrentViewModel);
|
||||||
|
taskCompletionSource = new();
|
||||||
|
await taskCompletionSource.Task.WaitAsync(CancellationToken.None);
|
||||||
|
Assert.Single(main.Strings);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Func<Task> Part1Func()
|
Func<Task> Part1Func()
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ namespace WpfViewModelFirst
|
|||||||
{
|
{
|
||||||
public interface IViewModelFactory
|
public interface IViewModelFactory
|
||||||
{
|
{
|
||||||
Part1ViewModel GetPart1ViewModel(Action finishAction);
|
Part1ViewModel GetPart1ViewModel(Func<Task> finishAction);
|
||||||
Part2ViewModel GetPart2ViewModel();
|
Part2ViewModel GetPart2ViewModel();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -29,11 +29,11 @@ namespace WpfViewModelFirst
|
|||||||
CurrentViewModel = null;
|
CurrentViewModel = null;
|
||||||
CurrentViewModel = _viewModelFactory.GetPart1ViewModel(Part1Action);
|
CurrentViewModel = _viewModelFactory.GetPart1ViewModel(Part1Action);
|
||||||
}
|
}
|
||||||
private void Part1Action()
|
private Task Part1Action()
|
||||||
{
|
{
|
||||||
CurrentViewModel = null;
|
CurrentViewModel = null;
|
||||||
var currentDispatcher = Dispatcher.CurrentDispatcher;
|
var currentDispatcher = Dispatcher.CurrentDispatcher;
|
||||||
LongDelay().ContinueWith((c) =>
|
return LongDelay().ContinueWith((c) =>
|
||||||
{
|
{
|
||||||
//System.Diagnostics.Debug.WriteLine(c.Result);
|
//System.Diagnostics.Debug.WriteLine(c.Result);
|
||||||
CurrentViewModel = _viewModelFactory.GetPart2ViewModel();
|
CurrentViewModel = _viewModelFactory.GetPart2ViewModel();
|
||||||
@@ -42,15 +42,19 @@ namespace WpfViewModelFirst
|
|||||||
{
|
{
|
||||||
Strings.Add($"{DateTime.Now}");
|
Strings.Add($"{DateTime.Now}");
|
||||||
});
|
});
|
||||||
|
ItHappened?.Invoke();
|
||||||
}, TaskContinuationOptions.OnlyOnRanToCompletion);
|
}, TaskContinuationOptions.OnlyOnRanToCompletion);
|
||||||
}
|
}
|
||||||
|
|
||||||
public event Action ItHappened;
|
public event Action? ItHappened;
|
||||||
|
|
||||||
private async Task<string> LongDelay()
|
private async Task<string> LongDelay()
|
||||||
{
|
{
|
||||||
// This would be the Repository call in the production application
|
// This would be the Repository call in the production application
|
||||||
|
await Task.Run(async () =>
|
||||||
|
{
|
||||||
await Task.Delay(500);
|
await Task.Delay(500);
|
||||||
|
});
|
||||||
return "Completed";
|
return "Completed";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -12,6 +12,9 @@
|
|||||||
<RowDefinition/>
|
<RowDefinition/>
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
<Button Grid.Row="0"
|
<Button Grid.Row="0"
|
||||||
|
HorizontalAlignment="Center"
|
||||||
|
VerticalAlignment="Center"
|
||||||
|
Padding="10"
|
||||||
Content="Finish"
|
Content="Finish"
|
||||||
Command="{Binding FinishCommand}"/>
|
Command="{Binding FinishCommand}"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|||||||
@@ -9,9 +9,9 @@ namespace WpfViewModelFirst.Part1
|
|||||||
{
|
{
|
||||||
public class Part1ViewModel : ViewModelBase
|
public class Part1ViewModel : ViewModelBase
|
||||||
{
|
{
|
||||||
private readonly Action _finishAction;
|
private readonly Func<Task> _finishAction;
|
||||||
|
|
||||||
public Part1ViewModel(Action finishAction)
|
public Part1ViewModel(Func<Task> finishAction)
|
||||||
{
|
{
|
||||||
_finishAction = finishAction;
|
_finishAction = finishAction;
|
||||||
FinishCommand = new CustomCommand(Finish);
|
FinishCommand = new CustomCommand(Finish);
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ namespace WpfViewModelFirst
|
|||||||
{
|
{
|
||||||
public class ViewModelFactory : IViewModelFactory
|
public class ViewModelFactory : IViewModelFactory
|
||||||
{
|
{
|
||||||
public Part1.Part1ViewModel GetPart1ViewModel(Action finishAction)
|
public Part1.Part1ViewModel GetPart1ViewModel(Func<Task> finishAction)
|
||||||
{
|
{
|
||||||
return new(finishAction);
|
return new(finishAction);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user