Mercurial > pub > bltoolkit
view UnitTests/Linq/UserTests/SelectManyUpdateTest.cs @ 4:f757da6161a1
!bug 100 + 2h fixed gregression
author | cin |
---|---|
date | Sun, 24 Aug 2014 17:57:42 +0400 |
parents | f990fcb411a9 |
children |
line wrap: on
line source
using System; using System.Collections.Generic; using System.Linq; using BLToolkit.Data.DataProvider; using BLToolkit.Data.Linq; using BLToolkit.DataAccess; using BLToolkit.Mapping; using NUnit.Framework; namespace Data.Linq.UserTests { [TestFixture] public class SelectManyUpdateTest : TestBase { public new class Child { [Identity, PrimaryKey(1)] public int ParentID { get; set; } [Nullable] public int? ChildID { get; set; } [AssociationAttribute(ThisKey = "ParentID", OtherKey = "ChildID", CanBeNull = true)] public List<Child> Children { get; set; } } public new class Parent { [Identity, PrimaryKey(1)] public int ParentID { get; set; } [Nullable] public int? Value1 { get; set; } [AssociationAttribute(ThisKey = "ParentID", OtherKey = "Value1", CanBeNull = true)] public List<Parent> Values { get; set; } [AssociationAttribute(ThisKey = "ParentID", OtherKey = "ParentID", CanBeNull = true)] public List<Child> Children { get; set; } } [Test] public void Test1([DataContexts(ProviderName.Access, ProviderName.Informix, ProviderName.MySql)] string context) { var harnessIds = new int[2]; using (var db = GetDataContext(context)) db.GetTable<Parent>() .Where (x => harnessIds.Contains(x.ParentID)) .SelectMany(x => x.Values) .Set (x => x.Value1, (long?)null) .Update(); } [Test] public void Test2([DataContexts(ProviderName.Access, ProviderName.Informix, ProviderName.MySql)] string context) { var harnessIds = new int[2]; using (var db = GetDataContext(context)) db.GetTable<Parent>() .Where (x => harnessIds.Contains(x.ParentID)) .SelectMany(x => x.Children) .SelectMany(x => x.Children) .Set (x => x.ChildID, 10) .Update(); } } }