// Authors: // Rafael Mizrahi // Erez Lotan // Oren Gurfinkel // Ofer Borstein // // Copyright (c) 2004 Mainsoft Co. // // 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.Data; using System.IO; using System.Collections; // Provide All Data required by the diffderent tests e.g.DataTable, DataRow ... namespace MonoTests.System.Data.Utils { public class DataProvider { #region Constatntas #region Private //A string containing all printable charachters. private const string SAMPLE_STRING = "abcdefghijklmnopqrstuvwxyz1234567890~!@#$%^&*()_+-=[]\\|;:,./<>? "; #endregion #endregion public static DataTable CreateChildDataTable() { DataTable dtChild = new DataTable("Child"); dtChild.Columns.Add("ParentId",typeof(int)); dtChild.Columns.Add("ChildId",typeof(int)); dtChild.Columns.Add("String1",typeof(string)); dtChild.Columns.Add("String2",typeof(string)); dtChild.Columns.Add("ChildDateTime",typeof(DateTime)); dtChild.Columns.Add("ChildDouble",typeof(double)); dtChild.Rows.Add(new object[] {1,1,"1-String1","1-String2",new DateTime(2000,1,1,0,0,0,0),1.534}); dtChild.Rows.Add(new object[] {1,2,"2-String1","2-String2",DateTime.MaxValue ,-1.534}); dtChild.Rows.Add(new object[] {1,3,"3-String1","3-String2",DateTime.MinValue,double.MaxValue/10000}); dtChild.Rows.Add(new object[] {2,1,"1-String1","1-String2",new DateTime(1973,6,20,0,0,0,0),double.MinValue*10000}); dtChild.Rows.Add(new object[] {2,2,"2-String1","2-String2",new DateTime(2008,12,1,13,59,59,59),0.45}); dtChild.Rows.Add(new object[] {2,3,"3-String1","3-String2",new DateTime(2003,1,1,1,1,1,1),0.55}); dtChild.Rows.Add(new object[] {5,1,"1-String1","1-String2",new DateTime(2002,1,1,1,1,1,1),0}); dtChild.Rows.Add(new object[] {5,2,"2-String1","2-String2",new DateTime(2001,1,1,1,1,1,1),10}); dtChild.Rows.Add(new object[] {5,3,"3-String1","3-String2",new DateTime(2000,1,1,1,1,1,1),20}); dtChild.Rows.Add(new object[] {6,1,"1-String1","1-String2",new DateTime(2000,1,1,1,1,1,0),25}); dtChild.Rows.Add(new object[] {6,2,"2-String1","2-String2",new DateTime(2000,1,1,1,1,0,0),30}); dtChild.Rows.Add(new object[] {6,3,"3-String1","3-String2",new DateTime(2000,1,1,0,0,0,0),35}); dtChild.AcceptChanges(); return dtChild; } public static DataTable CreateParentDataTable() { DataTable dtParent = new DataTable("Parent"); dtParent.Columns.Add("ParentId",typeof(int)); dtParent.Columns.Add("String1",typeof(string)); dtParent.Columns.Add("String2",typeof(string)); dtParent.Columns.Add("ParentDateTime",typeof(DateTime)); dtParent.Columns.Add("ParentDouble",typeof(double)); dtParent.Columns.Add("ParentBool",typeof(bool)); dtParent.Rows.Add(new object[] {1,"1-String1","1-String2",new DateTime(2005,1,1,0,0,0,0),1.534,true}); dtParent.Rows.Add(new object[] {2,"2-String1","2-String2",new DateTime(2004,1,1,0,0,0,1),-1.534,true}); dtParent.Rows.Add(new object[] {3,"3-String1","3-String2",new DateTime(2003,1,1,0,0,1,0),double.MinValue*10000,false}); dtParent.Rows.Add(new object[] {4,"4-String1","4-String2",new DateTime(2002,1,1,0,1,0,0),double.MaxValue/10000,true}); dtParent.Rows.Add(new object[] {5,"5-String1","5-String2",new DateTime(2001,1,1,1,0,0,0),0.755,true}); dtParent.Rows.Add(new object[] {6,"6-String1","6-String2",new DateTime(2000,1,1,0,0,0,0),0.001,false}); dtParent.AcceptChanges(); return dtParent; } //This method replace the DataSet GetXmlSchema method //used to compare DataSets //Created by Ofer (13-Nov-03) becuase DataSet GetXmlSchema method is not yet implemented in java public static string GetDSSchema(DataSet ds) { string strSchema = "DataSet Name=" + ds.DataSetName + "\n"; //Get relations foreach (DataRelation dl in ds.Relations) { strSchema += "\t" + "DataRelation Name=" + dl.RelationName ; foreach (DataColumn dc in dl.ParentColumns) strSchema += "\t" + "ParentColummn=" + dc.ColumnName ; foreach (DataColumn dc in dl.ChildColumns ) strSchema += "\t" + "ChildColumn=" + dc.ColumnName ; strSchema += "\n"; } //Get teables foreach (DataTable dt in ds.Tables) { strSchema += "Table=" + dt.TableName + "\t"; //Get Constraints strSchema += "Constraints ="; foreach (Constraint cs in dt.Constraints ) strSchema += cs.GetType().Name + ", "; strSchema += "\n"; //Get PrimaryKey Columns strSchema += "PrimaryKey Columns index:="; foreach (DataColumn dc in dt.PrimaryKey) strSchema += dc.Ordinal + ", "; strSchema += "\n"; //Get Columns foreach (DataColumn dc in dt.Columns) { strSchema += "ColumnName=" + dc.ColumnName + "\t" + "ColumnType=" + dc.DataType.Name + "\t" + "AllowDBNull=" + dc.AllowDBNull.ToString() + "\t" + "DefaultValue=" + dc.DefaultValue.ToString() + "\t" + "Unique=" + dc.Unique.ToString() + "\t" + "ReadOnly=" + dc.ReadOnly.ToString() + "\n" ; } strSchema += "\n"; } return strSchema; } public static DataTable CreateUniqueConstraint() { DataTable dt = DataProvider.CreateParentDataTable(); return CreateUniqueConstraint(dt); } public static DataTable CreateUniqueConstraint(DataTable dt) { Constraint con = new UniqueConstraint(dt.Columns["ParentId"]); dt.Constraints.Add(con); return dt; } public static void TryToBreakUniqueConstraint() { //Create the constraint DataTable dt = CreateUniqueConstraint(); //Try to violate the constraint DataRow dr1 = dt.NewRow(); dr1[0] = 1; dt.Rows.Add(dr1); } public static DataSet CreateForigenConstraint() { DataTable parent = DataProvider.CreateParentDataTable(); DataTable child = DataProvider.CreateChildDataTable(); DataSet ds = new DataSet(); ds.Tables.Add(parent); ds.Tables.Add(child); Constraint con1 = new ForeignKeyConstraint(parent.Columns[0],child.Columns[0]); child.Constraints.Add(con1); return ds; } public static void TryToBreakForigenConstraint() { DataSet ds = CreateForigenConstraint(); //Code to break: DataRow dr = ds.Tables[1].NewRow(); dr[0]=7; ds.Tables[1].Rows.Add(dr); ds.AcceptChanges(); ds.EnforceConstraints=true; } } }