Skip to content

Commit

Permalink
Add command to see the unresolved transactions (#16589)
Browse files Browse the repository at this point in the history
Signed-off-by: Manan Gupta <manan@planetscale.com>
  • Loading branch information
GuptaManan100 authored Aug 14, 2024
1 parent cc68dd5 commit 0af3d38
Show file tree
Hide file tree
Showing 20 changed files with 10,141 additions and 9,714 deletions.
66 changes: 66 additions & 0 deletions go/test/endtoend/transaction/twopc/twopc_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -964,6 +964,72 @@ func testWarningAndTransactionStatus(t *testing.T, conn *vtgateconn.VTGateSessio
}
}

// TestReadingUnresolvedTransactions tests the reading of unresolved transactions
func TestReadingUnresolvedTransactions(t *testing.T) {
testcases := []struct {
name string
queries []string
}{
{
name: "show transaction status for explicit keyspace",
queries: []string{
fmt.Sprintf("show unresolved transactions for %v", keyspaceName),
},
},
{
name: "show transaction status with use command",
queries: []string{
fmt.Sprintf("use %v", keyspaceName),
"show unresolved transactions",
},
},
}
for _, testcase := range testcases {
t.Run(testcase.name, func(t *testing.T) {
conn, closer := start(t)
defer closer()
// Start an atomic transaction.
utils.Exec(t, conn, "begin")
// Insert rows such that they go to all the three shards. Given that we have sharded the table `twopc_t1` on reverse_bits
// it is very easy to figure out what value will end up in which shard.
utils.Exec(t, conn, "insert into twopc_t1(id, col) values(4, 4)")
utils.Exec(t, conn, "insert into twopc_t1(id, col) values(6, 4)")
utils.Exec(t, conn, "insert into twopc_t1(id, col) values(9, 4)")
// We want to delay the commit on one of the shards to simulate slow commits on a shard.
writeTestCommunicationFile(t, DebugDelayCommitShard, "80-")
defer deleteFile(DebugDelayCommitShard)
writeTestCommunicationFile(t, DebugDelayCommitTime, "5")
defer deleteFile(DebugDelayCommitTime)
// We will execute a commit in a go routine, because we know it will take some time to complete.
// While the commit is ongoing, we would like to check that we see the unresolved transaction.
var wg sync.WaitGroup
wg.Add(1)
go func() {
defer wg.Done()
_, err := utils.ExecAllowError(t, conn, "commit")
if err != nil {
log.Errorf("Error in commit - %v", err)
}
}()
// Allow enough time for the commit to have started.
time.Sleep(1 * time.Second)
var lastRes *sqltypes.Result
newConn, err := mysql.Connect(context.Background(), &vtParams)
require.NoError(t, err)
defer newConn.Close()
for _, query := range testcase.queries {
lastRes = utils.Exec(t, newConn, query)
}
require.NotNil(t, lastRes)
require.Len(t, lastRes.Rows, 1)
// This verifies that we already decided to commit the transaction, but it is still unresolved.
assert.Contains(t, fmt.Sprintf("%v", lastRes.Rows), `VARCHAR("COMMIT")`)
// Wait for the commit to have returned.
wg.Wait()
})
}
}

// TestDisruptions tests that atomic transactions persevere through various disruptions.
func TestDisruptions(t *testing.T) {
testcases := []struct {
Expand Down
1 change: 1 addition & 0 deletions go/vt/sqlparser/ast.go
Original file line number Diff line number Diff line change
Expand Up @@ -1673,6 +1673,7 @@ type (

// ShowTransactionStatus is used to see the status of a distributed transaction in progress.
ShowTransactionStatus struct {
Keyspace string
TransactionID string
}

Expand Down
3 changes: 2 additions & 1 deletion go/vt/sqlparser/ast_equals.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 7 additions & 0 deletions go/vt/sqlparser/ast_format.go
Original file line number Diff line number Diff line change
Expand Up @@ -2152,6 +2152,13 @@ func (node *ShowBasic) Format(buf *TrackedBuffer) {
}

func (node *ShowTransactionStatus) Format(buf *TrackedBuffer) {
if node.TransactionID == "" {
buf.astPrintf(node, "show unresolved transactions")
if node.Keyspace != "" {
buf.astPrintf(node, " for %#s", node.Keyspace)
}
return
}
buf.astPrintf(node, "show transaction status for '%#s'", node.TransactionID)
}

Expand Down
8 changes: 8 additions & 0 deletions go/vt/sqlparser/ast_format_fast.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 3 additions & 1 deletion go/vt/sqlparser/cached_size.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions go/vt/sqlparser/keywords.go
Original file line number Diff line number Diff line change
Expand Up @@ -713,6 +713,7 @@ var keywords = []keyword{
{"to", TO},
{"trailing", TRAILING},
{"transaction", TRANSACTION},
{"transactions", TRANSACTIONS},
{"tree", TREE},
{"traditional", TRADITIONAL},
{"trigger", TRIGGER},
Expand All @@ -729,6 +730,7 @@ var keywords = []keyword{
{"unique", UNIQUE},
{"unknown", UNKNOWN},
{"unlock", UNLOCK},
{"unresolved", UNRESOLVED},
{"unsigned", UNSIGNED},
{"unthrottle", UNTHROTTLE},
{"update", UPDATE},
Expand Down
4 changes: 4 additions & 0 deletions go/vt/sqlparser/parse_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2442,6 +2442,10 @@ var (
}, {
input: "show transaction status \"ks:-80:232323238342\"",
output: "show transaction status for 'ks:-80:232323238342'",
}, {
input: "show unresolved transactions",
}, {
input: "show unresolved transactions for ks",
}, {
input: "revert vitess_migration '9748c3b7_7fdb_11eb_ac2c_f875a4d24e90'",
}, {
Expand Down
Loading

0 comments on commit 0af3d38

Please sign in to comment.