aboutsummaryrefslogtreecommitdiff
path: root/src/test/isolation/specs/aborted-keyrevoke.spec
blob: c60aa0cebb2c739ea276b5b9187e4718c3c87993 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# When a tuple that has been updated is locked, the locking command
# should traverse the update chain; thus, a DELETE should not be able
# to proceed until the lock has been released.

setup
{
  CREATE TABLE foo (
	key		int PRIMARY KEY,
	value	int
  );

  INSERT INTO foo VALUES (1, 1);
}

teardown
{
  DROP TABLE foo;
}

session "s1"
setup		{ BEGIN; }
step "s1s"	{ SAVEPOINT f; }
step "s1u"	{ UPDATE foo SET key = 2; }	# obtain KEY REVOKE
step "s1r"	{ ROLLBACK TO f; } # lose KEY REVOKE
step "s1l"	{ SELECT * FROM foo FOR KEY SHARE; }
step "s1c"	{ COMMIT; }

session "s2"
setup		{ BEGIN; }
step "s2l"	{ SELECT * FROM foo FOR KEY SHARE; }
step "s2c"	{ COMMIT; }