Commit 62fd1afc authored by Heikki Linnakangas's avatar Heikki Linnakangas

Strip whitespace from SQL blocks in the isolation test suite. This is purely

cosmetic, it removes a lot of IMHO ugly whitespace from the expected output.
parent 0f7acbed
Parsed test spec with 2 sessions Parsed test spec with 2 sessions
starting permutation: ins com upd starting permutation: ins com upd
step ins: INSERT INTO bar VALUES (42); step ins: INSERT INTO bar VALUES (42);
step com: COMMIT; step com: COMMIT;
step upd: UPDATE foo SET b = 'Hello World'; step upd: UPDATE foo SET b = 'Hello World';
starting permutation: ins upd com starting permutation: ins upd com
step ins: INSERT INTO bar VALUES (42); step ins: INSERT INTO bar VALUES (42);
step upd: UPDATE foo SET b = 'Hello World'; <waiting ...> step upd: UPDATE foo SET b = 'Hello World'; <waiting ...>
step com: COMMIT; step com: COMMIT;
step upd: <... completed> step upd: <... completed>
starting permutation: upd ins com starting permutation: upd ins com
step upd: UPDATE foo SET b = 'Hello World'; step upd: UPDATE foo SET b = 'Hello World';
step ins: INSERT INTO bar VALUES (42); step ins: INSERT INTO bar VALUES (42);
step com: COMMIT; step com: COMMIT;
Parsed test spec with 2 sessions Parsed test spec with 2 sessions
starting permutation: s1i s1u s1c s2i s2u s2c starting permutation: s1i s1u s1c s2i s2u s2c
step s1i: INSERT INTO child VALUES (1, 1); step s1i: INSERT INTO child VALUES (1, 1);
step s1u: UPDATE parent SET aux = 'bar'; step s1u: UPDATE parent SET aux = 'bar';
step s1c: COMMIT; step s1c: COMMIT;
step s2i: INSERT INTO child VALUES (2, 1); step s2i: INSERT INTO child VALUES (2, 1);
step s2u: UPDATE parent SET aux = 'baz'; step s2u: UPDATE parent SET aux = 'baz';
step s2c: COMMIT; step s2c: COMMIT;
starting permutation: s1i s1u s2i s1c s2u s2c starting permutation: s1i s1u s2i s1c s2u s2c
step s1i: INSERT INTO child VALUES (1, 1); step s1i: INSERT INTO child VALUES (1, 1);
step s1u: UPDATE parent SET aux = 'bar'; step s1u: UPDATE parent SET aux = 'bar';
step s2i: INSERT INTO child VALUES (2, 1); <waiting ...> step s2i: INSERT INTO child VALUES (2, 1); <waiting ...>
step s1c: COMMIT; step s1c: COMMIT;
step s2i: <... completed> step s2i: <... completed>
step s2u: UPDATE parent SET aux = 'baz'; step s2u: UPDATE parent SET aux = 'baz';
step s2c: COMMIT; step s2c: COMMIT;
starting permutation: s1i s2i s1u s2u s1c s2c starting permutation: s1i s2i s1u s2u s1c s2c
step s1i: INSERT INTO child VALUES (1, 1); step s1i: INSERT INTO child VALUES (1, 1);
step s2i: INSERT INTO child VALUES (2, 1); step s2i: INSERT INTO child VALUES (2, 1);
step s1u: UPDATE parent SET aux = 'bar'; <waiting ...> step s1u: UPDATE parent SET aux = 'bar'; <waiting ...>
step s2u: UPDATE parent SET aux = 'baz'; step s2u: UPDATE parent SET aux = 'baz';
step s1u: <... completed> step s1u: <... completed>
ERROR: deadlock detected ERROR: deadlock detected
step s1c: COMMIT; step s1c: COMMIT;
step s2c: COMMIT; step s2c: COMMIT;
starting permutation: s1i s2i s2u s1u s2c s1c starting permutation: s1i s2i s2u s1u s2c s1c
step s1i: INSERT INTO child VALUES (1, 1); step s1i: INSERT INTO child VALUES (1, 1);
step s2i: INSERT INTO child VALUES (2, 1); step s2i: INSERT INTO child VALUES (2, 1);
step s2u: UPDATE parent SET aux = 'baz'; <waiting ...> step s2u: UPDATE parent SET aux = 'baz'; <waiting ...>
step s1u: UPDATE parent SET aux = 'bar'; step s1u: UPDATE parent SET aux = 'bar';
ERROR: deadlock detected ERROR: deadlock detected
step s2u: <... completed> step s2u: <... completed>
step s2c: COMMIT; step s2c: COMMIT;
step s1c: COMMIT; step s1c: COMMIT;
starting permutation: s2i s1i s1u s2u s1c s2c starting permutation: s2i s1i s1u s2u s1c s2c
step s2i: INSERT INTO child VALUES (2, 1); step s2i: INSERT INTO child VALUES (2, 1);
step s1i: INSERT INTO child VALUES (1, 1); step s1i: INSERT INTO child VALUES (1, 1);
step s1u: UPDATE parent SET aux = 'bar'; <waiting ...> step s1u: UPDATE parent SET aux = 'bar'; <waiting ...>
step s2u: UPDATE parent SET aux = 'baz'; step s2u: UPDATE parent SET aux = 'baz';
step s1u: <... completed> step s1u: <... completed>
ERROR: deadlock detected ERROR: deadlock detected
step s1c: COMMIT; step s1c: COMMIT;
step s2c: COMMIT; step s2c: COMMIT;
starting permutation: s2i s1i s2u s1u s2c s1c starting permutation: s2i s1i s2u s1u s2c s1c
step s2i: INSERT INTO child VALUES (2, 1); step s2i: INSERT INTO child VALUES (2, 1);
step s1i: INSERT INTO child VALUES (1, 1); step s1i: INSERT INTO child VALUES (1, 1);
step s2u: UPDATE parent SET aux = 'baz'; <waiting ...> step s2u: UPDATE parent SET aux = 'baz'; <waiting ...>
step s1u: UPDATE parent SET aux = 'bar'; step s1u: UPDATE parent SET aux = 'bar';
ERROR: deadlock detected ERROR: deadlock detected
step s2u: <... completed> step s2u: <... completed>
step s2c: COMMIT; step s2c: COMMIT;
step s1c: COMMIT; step s1c: COMMIT;
starting permutation: s2i s2u s1i s2c s1u s1c starting permutation: s2i s2u s1i s2c s1u s1c
step s2i: INSERT INTO child VALUES (2, 1); step s2i: INSERT INTO child VALUES (2, 1);
step s2u: UPDATE parent SET aux = 'baz'; step s2u: UPDATE parent SET aux = 'baz';
step s1i: INSERT INTO child VALUES (1, 1); <waiting ...> step s1i: INSERT INTO child VALUES (1, 1); <waiting ...>
step s2c: COMMIT; step s2c: COMMIT;
step s1i: <... completed> step s1i: <... completed>
step s1u: UPDATE parent SET aux = 'bar'; step s1u: UPDATE parent SET aux = 'bar';
step s1c: COMMIT; step s1c: COMMIT;
Parsed test spec with 2 sessions Parsed test spec with 2 sessions
starting permutation: s1u1 s1u2 s1c s2u1 s2u2 s2c starting permutation: s1u1 s1u2 s1c s2u1 s2u2 s2c
step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1;
step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1c: COMMIT; step s1c: COMMIT;
step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s2c: COMMIT; step s2c: COMMIT;
starting permutation: s1u1 s1u2 s2u1 s1c s2u2 s2c starting permutation: s1u1 s1u2 s2u1 s1c s2u2 s2c
step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1;
step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...> step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...>
step s1c: COMMIT; step s1c: COMMIT;
step s2u1: <... completed> step s2u1: <... completed>
step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s2c: COMMIT; step s2c: COMMIT;
starting permutation: s1u1 s2u1 s1u2 s2u2 s1c s2c starting permutation: s1u1 s2u1 s1u2 s2u2 s1c s2c
step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1;
step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...> step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...>
step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1u2: <... completed> step s1u2: <... completed>
ERROR: deadlock detected ERROR: deadlock detected
step s1c: COMMIT; step s1c: COMMIT;
step s2c: COMMIT; step s2c: COMMIT;
starting permutation: s1u1 s2u1 s1u2 s2u2 s2c s1c starting permutation: s1u1 s2u1 s1u2 s2u2 s2c s1c
step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1;
step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...> step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...>
step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1u2: <... completed> step s1u2: <... completed>
ERROR: deadlock detected ERROR: deadlock detected
step s2c: COMMIT; step s2c: COMMIT;
step s1c: COMMIT; step s1c: COMMIT;
starting permutation: s1u1 s2u1 s2u2 s1u2 s1c s2c starting permutation: s1u1 s2u1 s2u2 s1u2 s1c s2c
step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1;
step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...> step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...>
step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
ERROR: deadlock detected ERROR: deadlock detected
step s2u2: <... completed> step s2u2: <... completed>
step s1c: COMMIT; step s1c: COMMIT;
step s2c: COMMIT; step s2c: COMMIT;
starting permutation: s1u1 s2u1 s2u2 s1u2 s2c s1c starting permutation: s1u1 s2u1 s2u2 s1u2 s2c s1c
step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1;
step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...> step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...>
step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
ERROR: deadlock detected ERROR: deadlock detected
step s2u2: <... completed> step s2u2: <... completed>
step s2c: COMMIT; step s2c: COMMIT;
step s1c: COMMIT; step s1c: COMMIT;
starting permutation: s2u1 s1u1 s1u2 s2u2 s1c s2c starting permutation: s2u1 s1u1 s1u2 s2u2 s1c s2c
step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1;
step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...> step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...>
step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1u2: <... completed> step s1u2: <... completed>
ERROR: deadlock detected ERROR: deadlock detected
step s1c: COMMIT; step s1c: COMMIT;
step s2c: COMMIT; step s2c: COMMIT;
starting permutation: s2u1 s1u1 s1u2 s2u2 s2c s1c starting permutation: s2u1 s1u1 s1u2 s2u2 s2c s1c
step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1;
step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...> step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...>
step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1u2: <... completed> step s1u2: <... completed>
ERROR: deadlock detected ERROR: deadlock detected
step s2c: COMMIT; step s2c: COMMIT;
step s1c: COMMIT; step s1c: COMMIT;
starting permutation: s2u1 s1u1 s2u2 s1u2 s1c s2c starting permutation: s2u1 s1u1 s2u2 s1u2 s1c s2c
step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1;
step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...> step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...>
step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
ERROR: deadlock detected ERROR: deadlock detected
step s2u2: <... completed> step s2u2: <... completed>
step s1c: COMMIT; step s1c: COMMIT;
step s2c: COMMIT; step s2c: COMMIT;
starting permutation: s2u1 s1u1 s2u2 s1u2 s2c s1c starting permutation: s2u1 s1u1 s2u2 s1u2 s2c s1c
step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1;
step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...> step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; <waiting ...>
step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
ERROR: deadlock detected ERROR: deadlock detected
step s2u2: <... completed> step s2u2: <... completed>
step s2c: COMMIT; step s2c: COMMIT;
step s1c: COMMIT; step s1c: COMMIT;
starting permutation: s2u1 s2u2 s1u1 s2c s1u2 s1c starting permutation: s2u1 s2u2 s1u1 s2c s1u2 s1c
step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u1: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s2u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; <waiting ...> step s1u1: UPDATE A SET Col1 = 1 WHERE AID = 1; <waiting ...>
step s2c: COMMIT; step s2c: COMMIT;
step s1u1: <... completed> step s1u1: <... completed>
step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2; step s1u2: UPDATE B SET Col2 = 1 WHERE BID = 2;
step s1c: COMMIT; step s1c: COMMIT;
Parsed test spec with 4 sessions Parsed test spec with 4 sessions
starting permutation: rx1 wx2 c2 wx3 ry3 wy4 rz4 c4 c3 wz1 c1 starting permutation: rx1 wx2 c2 wx3 ry3 wy4 rz4 c4 c3 wz1 c1
step rx1: SELECT * FROM t WHERE id = 1000000; step rx1: SELECT * FROM t WHERE id = 1000000;
id txt id txt
1000000 1000000
step wx2: UPDATE t SET txt = 'b' WHERE id = 1000000; step wx2: UPDATE t SET txt = 'b' WHERE id = 1000000;
step c2: COMMIT; step c2: COMMIT;
step wx3: UPDATE t SET txt = 'c' WHERE id = 1000000; step wx3: UPDATE t SET txt = 'c' WHERE id = 1000000;
step ry3: SELECT * FROM t WHERE id = 500000; step ry3: SELECT * FROM t WHERE id = 500000;
id txt id txt
500000 500000
step wy4: UPDATE t SET txt = 'd' WHERE id = 500000; step wy4: UPDATE t SET txt = 'd' WHERE id = 500000;
step rz4: SELECT * FROM t WHERE id = 1; step rz4: SELECT * FROM t WHERE id = 1;
id txt id txt
1 1
step c4: COMMIT; step c4: COMMIT;
step c3: COMMIT; step c3: COMMIT;
step wz1: UPDATE t SET txt = 'a' WHERE id = 1; step wz1: UPDATE t SET txt = 'a' WHERE id = 1;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
step c1: COMMIT; step c1: COMMIT;
Parsed test spec with 2 sessions Parsed test spec with 2 sessions
starting permutation: wxry1 c1 r2 wyrx2 c2 starting permutation: wxry1 c1 r2 wyrx2 c2
step wxry1: INSERT INTO child (parent_id) VALUES (0); step wxry1: INSERT INTO child (parent_id) VALUES (0);
step c1: COMMIT; step c1: COMMIT;
step r2: SELECT TRUE; step r2: SELECT TRUE;
bool bool
t t
step wyrx2: DELETE FROM parent WHERE parent_id = 0; step wyrx2: DELETE FROM parent WHERE parent_id = 0;
ERROR: child row exists ERROR: child row exists
step c2: COMMIT; step c2: COMMIT;
starting permutation: wxry1 r2 c1 wyrx2 c2 starting permutation: wxry1 r2 c1 wyrx2 c2
step wxry1: INSERT INTO child (parent_id) VALUES (0); step wxry1: INSERT INTO child (parent_id) VALUES (0);
step r2: SELECT TRUE; step r2: SELECT TRUE;
bool bool
t t
step c1: COMMIT; step c1: COMMIT;
step wyrx2: DELETE FROM parent WHERE parent_id = 0; step wyrx2: DELETE FROM parent WHERE parent_id = 0;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
step c2: COMMIT; step c2: COMMIT;
starting permutation: wxry1 r2 wyrx2 c1 c2 starting permutation: wxry1 r2 wyrx2 c1 c2
step wxry1: INSERT INTO child (parent_id) VALUES (0); step wxry1: INSERT INTO child (parent_id) VALUES (0);
step r2: SELECT TRUE; step r2: SELECT TRUE;
bool bool
t t
step wyrx2: DELETE FROM parent WHERE parent_id = 0; step wyrx2: DELETE FROM parent WHERE parent_id = 0;
step c1: COMMIT; step c1: COMMIT;
step c2: COMMIT; step c2: COMMIT;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
starting permutation: wxry1 r2 wyrx2 c2 c1 starting permutation: wxry1 r2 wyrx2 c2 c1
step wxry1: INSERT INTO child (parent_id) VALUES (0); step wxry1: INSERT INTO child (parent_id) VALUES (0);
step r2: SELECT TRUE; step r2: SELECT TRUE;
bool bool
t t
step wyrx2: DELETE FROM parent WHERE parent_id = 0; step wyrx2: DELETE FROM parent WHERE parent_id = 0;
step c2: COMMIT; step c2: COMMIT;
step c1: COMMIT; step c1: COMMIT;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
starting permutation: r2 wxry1 c1 wyrx2 c2 starting permutation: r2 wxry1 c1 wyrx2 c2
step r2: SELECT TRUE; step r2: SELECT TRUE;
bool bool
t t
step wxry1: INSERT INTO child (parent_id) VALUES (0); step wxry1: INSERT INTO child (parent_id) VALUES (0);
step c1: COMMIT; step c1: COMMIT;
step wyrx2: DELETE FROM parent WHERE parent_id = 0; step wyrx2: DELETE FROM parent WHERE parent_id = 0;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
step c2: COMMIT; step c2: COMMIT;
starting permutation: r2 wxry1 wyrx2 c1 c2 starting permutation: r2 wxry1 wyrx2 c1 c2
step r2: SELECT TRUE; step r2: SELECT TRUE;
bool bool
t t
step wxry1: INSERT INTO child (parent_id) VALUES (0); step wxry1: INSERT INTO child (parent_id) VALUES (0);
step wyrx2: DELETE FROM parent WHERE parent_id = 0; step wyrx2: DELETE FROM parent WHERE parent_id = 0;
step c1: COMMIT; step c1: COMMIT;
step c2: COMMIT; step c2: COMMIT;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
starting permutation: r2 wxry1 wyrx2 c2 c1 starting permutation: r2 wxry1 wyrx2 c2 c1
step r2: SELECT TRUE; step r2: SELECT TRUE;
bool bool
t t
step wxry1: INSERT INTO child (parent_id) VALUES (0); step wxry1: INSERT INTO child (parent_id) VALUES (0);
step wyrx2: DELETE FROM parent WHERE parent_id = 0; step wyrx2: DELETE FROM parent WHERE parent_id = 0;
step c2: COMMIT; step c2: COMMIT;
step c1: COMMIT; step c1: COMMIT;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
starting permutation: r2 wyrx2 wxry1 c1 c2 starting permutation: r2 wyrx2 wxry1 c1 c2
step r2: SELECT TRUE; step r2: SELECT TRUE;
bool bool
t t
step wyrx2: DELETE FROM parent WHERE parent_id = 0; step wyrx2: DELETE FROM parent WHERE parent_id = 0;
step wxry1: INSERT INTO child (parent_id) VALUES (0); step wxry1: INSERT INTO child (parent_id) VALUES (0);
step c1: COMMIT; step c1: COMMIT;
step c2: COMMIT; step c2: COMMIT;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
starting permutation: r2 wyrx2 wxry1 c2 c1 starting permutation: r2 wyrx2 wxry1 c2 c1
step r2: SELECT TRUE; step r2: SELECT TRUE;
bool bool
t t
step wyrx2: DELETE FROM parent WHERE parent_id = 0; step wyrx2: DELETE FROM parent WHERE parent_id = 0;
step wxry1: INSERT INTO child (parent_id) VALUES (0); step wxry1: INSERT INTO child (parent_id) VALUES (0);
step c2: COMMIT; step c2: COMMIT;
step c1: COMMIT; step c1: COMMIT;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
starting permutation: r2 wyrx2 c2 wxry1 c1 starting permutation: r2 wyrx2 c2 wxry1 c1
step r2: SELECT TRUE; step r2: SELECT TRUE;
bool bool
t t
step wyrx2: DELETE FROM parent WHERE parent_id = 0; step wyrx2: DELETE FROM parent WHERE parent_id = 0;
step c2: COMMIT; step c2: COMMIT;
step wxry1: INSERT INTO child (parent_id) VALUES (0); step wxry1: INSERT INTO child (parent_id) VALUES (0);
ERROR: parent row missing ERROR: parent row missing
step c1: COMMIT; step c1: COMMIT;
Parsed test spec with 2 sessions Parsed test spec with 2 sessions
starting permutation: rwx1 c1 rwx2 c2 starting permutation: rwx1 c1 rwx2 c2
step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear'; step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear';
step c1: COMMIT; step c1: COMMIT;
step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple' step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple'
step c2: COMMIT; step c2: COMMIT;
starting permutation: rwx1 rwx2 c1 c2 starting permutation: rwx1 rwx2 c1 c2
step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear'; step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear';
step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple' step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple'
step c1: COMMIT; step c1: COMMIT;
step c2: COMMIT; step c2: COMMIT;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
starting permutation: rwx1 rwx2 c2 c1 starting permutation: rwx1 rwx2 c2 c1
step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear'; step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear';
step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple' step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple'
step c2: COMMIT; step c2: COMMIT;
step c1: COMMIT; step c1: COMMIT;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
starting permutation: rwx2 rwx1 c1 c2 starting permutation: rwx2 rwx1 c1 c2
step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple' step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple'
step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear'; step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear';
step c1: COMMIT; step c1: COMMIT;
step c2: COMMIT; step c2: COMMIT;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
starting permutation: rwx2 rwx1 c2 c1 starting permutation: rwx2 rwx1 c2 c1
step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple' step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple'
step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear'; step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear';
step c2: COMMIT; step c2: COMMIT;
step c1: COMMIT; step c1: COMMIT;
ERROR: could not serialize access due to read/write dependencies among transactions ERROR: could not serialize access due to read/write dependencies among transactions
starting permutation: rwx2 c2 rwx1 c1 starting permutation: rwx2 c2 rwx1 c1
step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple' step rwx2: UPDATE test SET t = 'pear' WHERE t = 'apple'
step c2: COMMIT; step c2: COMMIT;
step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear'; step rwx1: UPDATE test SET t = 'apple' WHERE t = 'pear';
step c1: COMMIT; step c1: COMMIT;
This diff is collapsed.
This diff is collapsed.
...@@ -64,12 +64,12 @@ teardown { return(TEARDOWN); } ...@@ -64,12 +64,12 @@ teardown { return(TEARDOWN); }
<qstr><<EOF>> { yyerror("unterminated quoted string"); } <qstr><<EOF>> { yyerror("unterminated quoted string"); }
/* SQL blocks: { UPDATE ... } */ /* SQL blocks: { UPDATE ... } */
"{" { "{"{space}* {
litbufpos = 0; litbufpos = 0;
BEGIN(sql); BEGIN(sql);
} }
<sql>"}" { <sql>{space}*"}" {
litbuf[litbufpos] = '\0'; litbuf[litbufpos] = '\0';
yylval.str = strdup(litbuf); yylval.str = strdup(litbuf);
BEGIN(INITIAL); BEGIN(INITIAL);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment