| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | // | 
					
						
							|  |  |  | // EnumerableRowCollectionTest.cs | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // Author: | 
					
						
							|  |  |  | //   Atsushi Enomoto  <atsushi@ximian.com> | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // Copyright (C) 2008 Novell, Inc. http://www.novell.com | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // Permission is hereby granted, free of charge, to any person obtaining | 
					
						
							|  |  |  | // a copy of this software and associated documentation files (the | 
					
						
							|  |  |  | // "Software"), to deal in the Software without restriction, including | 
					
						
							|  |  |  | // without limitation the rights to use, copy, modify, merge, publish, | 
					
						
							|  |  |  | // distribute, sublicense, and/or sell copies of the Software, and to | 
					
						
							|  |  |  | // permit persons to whom the Software is furnished to do so, subject to | 
					
						
							|  |  |  | // the following conditions: | 
					
						
							|  |  |  | //  | 
					
						
							|  |  |  | // The above copyright notice and this permission notice shall be | 
					
						
							|  |  |  | // included in all copies or substantial portions of the Software. | 
					
						
							|  |  |  | //  | 
					
						
							|  |  |  | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | 
					
						
							|  |  |  | // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | 
					
						
							|  |  |  | // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | 
					
						
							|  |  |  | // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE | 
					
						
							|  |  |  | // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION | 
					
						
							|  |  |  | // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | 
					
						
							|  |  |  | // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | using System; | 
					
						
							|  |  |  | using System.Collections.Generic; | 
					
						
							|  |  |  | using System.Data; | 
					
						
							|  |  |  | using NUnit.Framework; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | using MonoTests.Helpers; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | namespace MonoTests.System.Data | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	[TestFixture] | 
					
						
							|  |  |  | 	public class EnumerableRowCollectionTest | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		[Test] | 
					
						
							|  |  |  | 		public void QueryWhere () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			var ds = new DataSet (); | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 			ds.ReadXml (TestResourceHelper.GetFullPathOfResource ("Test/System.Data/testdataset1.xml")); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 			var table = ds.Tables [0]; | 
					
						
							|  |  |  | 			/* schema generated as ... | 
					
						
							|  |  |  | 			var table = ds.Tables.Add ("ScoreList"); | 
					
						
							|  |  |  | 			table.Columns.Add ("ID", typeof (int)); | 
					
						
							|  |  |  | 			table.Columns.Add ("RegisteredDate", typeof (DateTime)); | 
					
						
							|  |  |  | 			table.Columns.Add ("Name", typeof (string)); | 
					
						
							|  |  |  | 			table.Columns.Add ("Score", typeof (int)); | 
					
						
							|  |  |  | 			ds.WriteXml ("Test/System.Data/testdataset1.xsd", XmlWriteMode.WriteSchema); | 
					
						
							|  |  |  | 			*/ | 
					
						
							|  |  |  | 			var q = from line in table.AsEnumerable () | 
					
						
							|  |  |  | 				where line.Field<int> ("Score") > 80 | 
					
						
							|  |  |  | 				select line; | 
					
						
							|  |  |  | 			bool iterated = false; | 
					
						
							|  |  |  | 			foreach (var line in q) { | 
					
						
							|  |  |  | 				if (iterated) | 
					
						
							|  |  |  | 					Assert.Fail ("should match only one raw"); | 
					
						
							|  |  |  | 				Assert.AreEqual (100, line ["Score"], "#1"); | 
					
						
							|  |  |  | 				iterated = true; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		[Test] | 
					
						
							|  |  |  | 		public void QueryWhereSelect () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			var ds = new DataSet (); | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 			ds.ReadXml (TestResourceHelper.GetFullPathOfResource ("Test/System.Data/testdataset1.xml")); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 			var table = ds.Tables [0]; | 
					
						
							|  |  |  | 			var q = from line in table.AsEnumerable () | 
					
						
							|  |  |  | 				where line.Field<int> ("Score") > 80 | 
					
						
							|  |  |  | 				select new { | 
					
						
							|  |  |  | 					StudentID = line.Field<int> ("ID"), | 
					
						
							|  |  |  | 					StudentName = line.Field<string> ("Name"), | 
					
						
							|  |  |  | 					StudentScore = line.Field<int> ("Score") }; | 
					
						
							|  |  |  | 			bool iterated = false; | 
					
						
							|  |  |  | 			foreach (var ql in q) { | 
					
						
							|  |  |  | 				if (iterated) | 
					
						
							|  |  |  | 					Assert.Fail ("should match only one raw"); | 
					
						
							|  |  |  | 				Assert.AreEqual (100, ql.StudentScore, "#1"); | 
					
						
							|  |  |  | 				iterated = true; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		[Test] | 
					
						
							|  |  |  | 		public void QueryWhereSelectOrderBy () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			var ds = new DataSet (); | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 			ds.ReadXml (TestResourceHelper.GetFullPathOfResource ("Test/System.Data/testdataset1.xml")); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 			var table = ds.Tables [0]; | 
					
						
							|  |  |  | 			var q = from line in table.AsEnumerable () | 
					
						
							|  |  |  | 				where line.Field<int> ("Score") >= 80 | 
					
						
							|  |  |  | 				orderby line.Field<int> ("ID") | 
					
						
							|  |  |  | 				select new { | 
					
						
							|  |  |  | 					StudentID = line.Field<int> ("ID"), | 
					
						
							|  |  |  | 					StudentName = line.Field<string> ("Name"), | 
					
						
							|  |  |  | 					StudentScore = line.Field<int> ("Score") }; | 
					
						
							|  |  |  | 			int prevID = -1; | 
					
						
							|  |  |  | 			foreach (var ql in q) { | 
					
						
							|  |  |  | 				switch (prevID) { | 
					
						
							|  |  |  | 				case -1: | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 					Assert.AreEqual (1, ql.StudentID, "#1"); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 					break; | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 				case 1: | 
					
						
							|  |  |  | 					Assert.AreEqual (4, ql.StudentID, "#2"); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 					break; | 
					
						
							|  |  |  | 				default: | 
					
						
							|  |  |  | 					Assert.Fail ("should match only one raw"); | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 					break; | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				prevID = ql.StudentID; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		[Test] | 
					
						
							|  |  |  | 		public void QueryWhereSelectOrderByDescending () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			var ds = new DataSet (); | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 			ds.ReadXml (TestResourceHelper.GetFullPathOfResource ("Test/System.Data/testdataset1.xml")); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 			var table = ds.Tables [0]; | 
					
						
							|  |  |  | 			var q = from line in table.AsEnumerable () | 
					
						
							|  |  |  | 				where line.Field<int> ("Score") >= 80 | 
					
						
							|  |  |  | 				orderby line.Field<int> ("ID") descending | 
					
						
							|  |  |  | 				select new { | 
					
						
							|  |  |  | 					StudentID = line.Field<int> ("ID"), | 
					
						
							|  |  |  | 					StudentName = line.Field<string> ("Name"), | 
					
						
							|  |  |  | 					StudentScore = line.Field<int> ("Score") }; | 
					
						
							|  |  |  | 			int prevID = -1; | 
					
						
							|  |  |  | 			foreach (var ql in q) { | 
					
						
							|  |  |  | 				switch (prevID) { | 
					
						
							|  |  |  | 				case -1: | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 					Assert.AreEqual (4, ql.StudentID, "#1"); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 					break; | 
					
						
							|  |  |  | 				case 4: | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 					Assert.AreEqual (1, ql.StudentID, "#2"); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 					break; | 
					
						
							|  |  |  | 				default: | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 					Assert.Fail ("should match only one raw, ID: " + ql.StudentID); | 
					
						
							|  |  |  | 					break; | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				prevID = ql.StudentID; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		[Test] | 
					
						
							|  |  |  | 		public void ThenBy () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			var ds = new DataSet (); | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 			ds.ReadXml (TestResourceHelper.GetFullPathOfResource ("Test/System.Data/testdataset1.xml")); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 			var table = ds.Tables [0]; | 
					
						
							|  |  |  | 			var q = from line in table.AsEnumerable () | 
					
						
							|  |  |  | 				where line.Field<int> ("Score") >= 80 | 
					
						
							|  |  |  | 				orderby line.Field<bool> ("Gender"), line.Field<int> ("ID") | 
					
						
							|  |  |  | 				select new { | 
					
						
							|  |  |  | 					StudentID = line.Field<int> ("ID"), | 
					
						
							|  |  |  | 					StudentName = line.Field<string> ("Name"), | 
					
						
							|  |  |  | 					StudentScore = line.Field<int> ("Score") }; | 
					
						
							|  |  |  | 			int prevID = -1; | 
					
						
							|  |  |  | 			foreach (var ql in q) { | 
					
						
							|  |  |  | 				switch (prevID) { | 
					
						
							|  |  |  | 				case -1: | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 					Assert.AreEqual (1, ql.StudentID, "#1"); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 					break; | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 				case 1: | 
					
						
							|  |  |  | 					Assert.AreEqual (4, ql.StudentID, "#2"); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 					break; | 
					
						
							|  |  |  | 				default: | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 					Assert.Fail ("should match only one raw, ID: " + ql.StudentID); | 
					
						
							|  |  |  | 					break; | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				prevID = ql.StudentID; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		[Test] | 
					
						
							|  |  |  | 		public void ThenByDescending () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			var ds = new DataSet (); | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 			ds.ReadXml (TestResourceHelper.GetFullPathOfResource ("Test/System.Data/testdataset1.xml")); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 			var table = ds.Tables [0]; | 
					
						
							|  |  |  | 			var q = from line in table.AsEnumerable () | 
					
						
							|  |  |  | 				where line.Field<int> ("Score") >= 80 | 
					
						
							|  |  |  | 				orderby line.Field<bool> ("Gender"), line.Field<int> ("ID") descending | 
					
						
							|  |  |  | 				select new { | 
					
						
							|  |  |  | 					StudentID = line.Field<int> ("ID"), | 
					
						
							|  |  |  | 					StudentName = line.Field<string> ("Name"), | 
					
						
							|  |  |  | 					StudentScore = line.Field<int> ("Score") }; | 
					
						
							|  |  |  | 			int prevID = -1; | 
					
						
							|  |  |  | 			foreach (var ql in q) { | 
					
						
							|  |  |  | 				switch (prevID) { | 
					
						
							|  |  |  | 				case -1: | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 					Assert.AreEqual (4, ql.StudentID, "#1"); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 					break; | 
					
						
							|  |  |  | 				case 4: | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 					Assert.AreEqual (1, ql.StudentID, "#2"); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 					break; | 
					
						
							|  |  |  | 				default: | 
					
						
							| 
									
										
										
										
											2019-02-04 20:11:37 +00:00
										 |  |  | 					Assert.Fail ("should match only one raw, ID: " + ql.StudentID); | 
					
						
							|  |  |  | 					break; | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				prevID = ql.StudentID; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |