public void DFSearchRecursiveWorksCorrectly() { //Arrange var tree = new Tree <int>(); int count = 0; for (int i = 0; i < 10; i++) { var node = new Tree <int> .TreeNode(count); count++; tree.Add(node); for (int j = 0; j < 10; j++) { var child = new Tree <int> .TreeNode(count); count++; tree.Add(child, node); for (int k = 0; k < 10; k++) { var newChild = new Tree <int> .TreeNode(count); count++; tree.Add(newChild, child); for (int f = 0; f < 20; f++) { var lastChild = new Tree <int> .TreeNode(count); count++; tree.Add(lastChild, newChild); } } } } //Act var search = new DFSearch <int>(); var actual = search.DFSearchRecursive(tree.Root); var expected = new List <int>(); foreach (var item in tree) { expected.Add(item); } //Assert CollectionAssert.AreEquivalent(expected, actual); }