// tmapped.cpp -- Regression test program, mapped view tests // $Id$ // This is part of Metakit, see http://www.equi4.com/metakit/ #include "regress.h" void TestBlockDel(int pos_, int len_) { printf("blockdel pos %d len %d\n", pos_, len_); c4_ViewProp p1 ("_B"); c4_IntProp p2 ("p2"); c4_Storage s1; c4_View v1 = s1.GetAs("v1[_B[p2:I]]"); int n = 0; static int sizes[] = {999, 999, 999, 2, 0}; for (int i = 0; sizes[i]; ++i) { c4_View v; v.SetSize(sizes[i]); for (int j = 0; j < sizes[i]; ++j) p2 (v[j]) = ++n; v1.Add(p1 [v]); } c4_View v2 = v1.Blocked(); A(v2.GetSize() == 2999); v2.RemoveAt(pos_, len_); A(v2.GetSize() == 2999 - len_); } void TestMapped() { B(m01, Hash mapping, 0); { c4_StringProp p1 ("p1"); c4_Storage s1; c4_View v1 = s1.GetAs("v1[p1:S]"); c4_View v2 = s1.GetAs("v2[_H:I,_R:I]"); c4_View v3 = v1.Hash(v2, 1); v3.Add(p1 ["b93655249726e5ef4c68e45033c2e0850570e1e07"]); v3.Add(p1 ["2ab03fba463d214f854a71ab5c951cea096887adf"]); v3.Add(p1 ["2e196eecb91b02c16c23360d8e1b205f0b3e3fa3d"]); A(v3.GetSize() == 3); // infinite loop in 2.4.0, reported by Nathan Rogers, July 2001 // happens when looking for missing key after a hash collision int f = v3.Find(p1 ["7c0734c9187133f34588517fb5b39294076f22ba3"]); A(f == -1); } E; // example from Steve Baxter, Nov 2001, after block perf bugfix // assertion failure on row 1001, due to commit data mismatch B(m02, Blocked view bug, 0) W(m02a); { c4_BytesProp p1 ("p1"); c4_Bytes h; c4_Storage s1 ("m02a", true); c4_View v1 = s1.GetAs("v1[_B[p1:B]]"); c4_View v2 = v1.Blocked(); for (int i = 0; i < 1005; ++i) { h.SetBuffer(2500 + i); v2.Add(p1 [h]); if (i >= 999) // will crash a few rounds later, at row 1001 s1.Commit(); } // reduce size to shorten the dump output v2.RemoveAt(0, 990); s1.Commit(); } D(m02a); R(m02a); E; B(m03, Hash adds, 0) W(m03a); { c4_StringProp p1 ("p1"); c4_Storage s1 ("m03a", true); c4_View d1 = s1.GetAs("d1[p1:S]"); c4_View m1 = s1.GetAs("m1[_H:I,_R:I]"); c4_View h1 = d1.Hash(m1); h1.Add(p1 ["one"]); s1.Commit(); c4_View d2 = s1.GetAs("d2[p1:S]"); c4_View m2 = s1.GetAs("m2[_H:I,_R:I]"); c4_View h2 = d2.Hash(m2); h1.Add(p1 ["two"]); h2.Add(p1 ["two"]); s1.Commit(); c4_View d3 = s1.GetAs("d3[p1:S]"); c4_View m3 = s1.GetAs("m3[_H:I,_R:I]"); c4_View h3 = d3.Hash(m3); h1.Add(p1 ["three"]); h2.Add(p1 ["three"]); h3.Add(p1 ["three"]); s1.Commit(); c4_View d4 = s1.GetAs("d4[p1:S]"); c4_View m4 = s1.GetAs("m4[_H:I,_R:I]"); c4_View h4 = d4.Hash(m4); h1.Add(p1 ["four"]); h2.Add(p1 ["four"]); h3.Add(p1 ["four"]); h4.Add(p1 ["four"]); s1.Commit(); } D(m03a); R(m03a); E; B(m04, Locate bug, 0) W(m04a); { c4_IntProp p1 ("p1"); c4_StringProp p2 ("p2"); c4_Storage s1 ("m04a", true); s1.AutoCommit(); c4_View v1 = s1.GetAs("v1[p1:I,p2:S]"); v1.Add(p1 [1] + p2 ["one"]); v1.Add(p1 [2] + p2 ["two"]); v1.Add(p1 [3] + p2 ["three"]); s1.Commit(); c4_View v2 = v1.Ordered(); A(v2.GetSize() == 3); v2.Add(p1 [6] + p2 ["six"]); v2.Add(p1 [5] + p2 ["five"]); v2.Add(p1 [4] + p2 ["four"]); A(v2.GetSize() == 6); A(v1.GetSize() == 6); A(p1 (v1[0]) == 1); A(p1 (v1[1]) == 2); A(p1 (v1[2]) == 3); A(p1 (v1[3]) == 4); A(p1 (v1[4]) == 5); A(p1 (v1[5]) == 6); A(v2.Find(p1 [4]) == 3); A(v2.Search(p1 [4]) == 3); int i1 = -1; A(v1.Locate(p1 [4], &i1) == 1); A(i1 == 3); int i2 = -1; A(v2.Locate(p1 [4], &i2) == 1); A(i2 == 3); } D(m04a); R(m04a); E; // subviews are not relocated properly with blocked views in 2.4.7 B(m05, Blocked view with subviews, 0) W(m05a); { char buf[10]; c4_StringProp p1 ("p1"); c4_IntProp p2 ("p2"); c4_ViewProp pSv ("sv"); c4_Storage s1 ("m05a", true); c4_View v1 = s1.GetAs("v1[_B[p1:S,sv[p2:I]]]"); c4_View v2 = v1.Blocked(); for (int i = 0; i < 1000; ++i) { sprintf(buf, "id-%d", i); v2.Add(p1 [buf]); c4_View v3 = pSv (v2[i]); v3.Add(p2 [i]); } for (int j = 0; j < 1; ++j) { sprintf(buf, "insert-%d", j); v2.InsertAt(500, p1 [buf]); } s1.Commit(); } D(m05a); R(m05a); E; // 2003/02/14 - assert fails for 2.4.8 in c4_Column::RemoveData B(m06, Blocked view multi-row deletion, 0) W(m06a); { c4_IntProp p1 ("p1"); c4_Storage s1 ("m06a", true); c4_View v1 = s1.GetAs("v1[p1:I]"); c4_View v2 = s1.GetAs("v2[_B[_H:I,_R:I]]"); c4_View v3 = v2.Blocked(); c4_View v4 = v1.Hash(v3, 1); v4.Add(p1 [1]); v4.Add(p1 [2]); v4.RemoveAt(1); for (int i = 100; i < 1000; ++i) { v4.Add(p1 [i]); } s1.Commit(); } D(m06a); R(m06a); E; // 2003/03/07 - still not correct on blocked veiw deletions B(m07, All blocked view multi-deletion cases, 0); { int i, j; for (i = 0; i < 2; ++i) { for (j = 1; j < 4; ++j) TestBlockDel(i, j); for (j = 998; j < 1002; ++j) TestBlockDel(i, j); for (j = 1998; j < 2002; ++j) TestBlockDel(i, j); } for (i = 998; i < 1002; ++i) { for (j = 1; j < 4; ++j) TestBlockDel(i, j); for (j = 998; j < 1002; ++j) TestBlockDel(i, j); } for (i = 1; i < 4; ++i) TestBlockDel(2999 - i, i); for (i = 998; i < 1002; ++i) TestBlockDel(2999 - i, i); for (i = 1998; i < 2002; ++i) TestBlockDel(2999 - i, i); } E; }