mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 08:30:25 +08:00 
			
		
		
		
	Always reuse transaction (#22362)
This commit is contained in:
		@@ -25,8 +25,62 @@ func TestInTransaction(t *testing.T) {
 | 
			
		||||
	assert.NoError(t, err)
 | 
			
		||||
	defer committer.Close()
 | 
			
		||||
	assert.True(t, db.InTransaction(ctx))
 | 
			
		||||
	assert.Error(t, db.WithTx(ctx, func(ctx context.Context) error {
 | 
			
		||||
	assert.NoError(t, db.WithTx(ctx, func(ctx context.Context) error {
 | 
			
		||||
		assert.True(t, db.InTransaction(ctx))
 | 
			
		||||
		return nil
 | 
			
		||||
	}))
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func TestTxContext(t *testing.T) {
 | 
			
		||||
	assert.NoError(t, unittest.PrepareTestDatabase())
 | 
			
		||||
 | 
			
		||||
	{ // create new transaction
 | 
			
		||||
		ctx, committer, err := db.TxContext(db.DefaultContext)
 | 
			
		||||
		assert.NoError(t, err)
 | 
			
		||||
		assert.True(t, db.InTransaction(ctx))
 | 
			
		||||
		assert.NoError(t, committer.Commit())
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	{ // reuse the transaction created by TxContext and commit it
 | 
			
		||||
		ctx, committer, err := db.TxContext(db.DefaultContext)
 | 
			
		||||
		engine := db.GetEngine(ctx)
 | 
			
		||||
		assert.NoError(t, err)
 | 
			
		||||
		assert.True(t, db.InTransaction(ctx))
 | 
			
		||||
		{
 | 
			
		||||
			ctx, committer, err := db.TxContext(ctx)
 | 
			
		||||
			assert.NoError(t, err)
 | 
			
		||||
			assert.True(t, db.InTransaction(ctx))
 | 
			
		||||
			assert.Equal(t, engine, db.GetEngine(ctx))
 | 
			
		||||
			assert.NoError(t, committer.Commit())
 | 
			
		||||
		}
 | 
			
		||||
		assert.NoError(t, committer.Commit())
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	{ // reuse the transaction created by TxContext and close it
 | 
			
		||||
		ctx, committer, err := db.TxContext(db.DefaultContext)
 | 
			
		||||
		engine := db.GetEngine(ctx)
 | 
			
		||||
		assert.NoError(t, err)
 | 
			
		||||
		assert.True(t, db.InTransaction(ctx))
 | 
			
		||||
		{
 | 
			
		||||
			ctx, committer, err := db.TxContext(ctx)
 | 
			
		||||
			assert.NoError(t, err)
 | 
			
		||||
			assert.True(t, db.InTransaction(ctx))
 | 
			
		||||
			assert.Equal(t, engine, db.GetEngine(ctx))
 | 
			
		||||
			assert.NoError(t, committer.Close())
 | 
			
		||||
		}
 | 
			
		||||
		assert.NoError(t, committer.Close())
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	{ // reuse the transaction created by WithTx
 | 
			
		||||
		assert.NoError(t, db.WithTx(db.DefaultContext, func(ctx context.Context) error {
 | 
			
		||||
			assert.True(t, db.InTransaction(ctx))
 | 
			
		||||
			{
 | 
			
		||||
				ctx, committer, err := db.TxContext(ctx)
 | 
			
		||||
				assert.NoError(t, err)
 | 
			
		||||
				assert.True(t, db.InTransaction(ctx))
 | 
			
		||||
				assert.NoError(t, committer.Commit())
 | 
			
		||||
			}
 | 
			
		||||
			return nil
 | 
			
		||||
		}))
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user