Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CASSGO-1 CASSGO-30 Native Protocol 5 Support #1822

Open
wants to merge 26 commits into
base: trunk
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 24 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
fbdaa2b
Support for Native Protocol 5 release version
worryg0d Jul 18, 2024
93fb4ad
Added 'IF NOT EXISTS' to table creation queries in integration tests
worryg0d Oct 16, 2024
d926108
Clarified comment on startup completed
worryg0d Oct 16, 2024
a1baea2
Returned panics on setting keyspace and now_in_seconds field when pro…
worryg0d Oct 16, 2024
b77aa18
Added description for TestLargeSizeQuery and TestQueryCompressionNotW…
worryg0d Oct 17, 2024
465332b
Removed startupCompleted from Conn obj
worryg0d Oct 17, 2024
f613eaa
Creating new inflight instance when newMetadataID is received
worryg0d Oct 17, 2024
380d660
Moved panics on flags computing stage for now_in_seconds and keyspace…
worryg0d Oct 17, 2024
8b7e64b
Methods renames and comments corrections
worryg0d Oct 18, 2024
2eb3fbe
Improved reading/writing segments code
worryg0d Oct 21, 2024
7a210f2
Removed replace lz4 from go.mod
worryg0d Oct 21, 2024
d8ab2fa
Improved frame segmentation before writing it to conn
worryg0d Oct 21, 2024
34db5ed
Improved error messages
worryg0d Oct 21, 2024
df5adc0
Additional check in recvPartialFrames
worryg0d Oct 21, 2024
a79c985
removed net.Conn and *bufio.Reader from Conn
worryg0d Oct 23, 2024
86130c0
Compressor append-like API
worryg0d Oct 24, 2024
1343003
Fix reading <new_metadata_id> in parseResultMetadata
worryg0d Oct 25, 2024
98e37c1
Updating prepared stmt metadata result set and result_metadata_id whe…
worryg0d Oct 25, 2024
31d10f9
Avoiding deadlock after updating the lru cache entry
worryg0d Oct 25, 2024
2a5056d
Integration test for Metadata_changed mechanism
worryg0d Oct 28, 2024
bf0d7fa
1. Updating info to ensure the code looking at the updated prepared stmt
worryg0d Oct 30, 2024
0592a90
1. Updated TestPrepareExecuteMetadataChangedFlag to validate Metadata…
worryg0d Oct 30, 2024
0298a00
1. Updated the way how the driver constructs stmt cache keys. The cur…
worryg0d Oct 30, 2024
a1a613c
Added skip for TestStmtCacheUsesOverriddenKeyspace and TestRoutingKey…
worryg0d Oct 31, 2024
e779e73
Go bump to 1.19
worryg0d Nov 7, 2024
5ca5382
Changed CI to run integration tests over proto 5 + lz4 compressor
worryg0d Nov 12, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
82 changes: 82 additions & 0 deletions batch_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
package gocql

import (
"github.com/stretchr/testify/require"
"testing"
"time"
)
Expand Down Expand Up @@ -84,3 +85,84 @@ func TestBatch_WithTimestamp(t *testing.T) {
t.Errorf("got ts %d, expected %d", storedTs, micros)
}
}

func TestBatch_WithNowInSeconds(t *testing.T) {
session := createSession(t)
defer session.Close()

if session.cfg.ProtoVersion < protoVersion5 {
t.Skip("Batch now in seconds are only available on protocol >= 5")
}

if err := createTable(session, `CREATE TABLE IF NOT EXISTS batch_now_in_seconds (id int primary key, val text)`); err != nil {
t.Fatal(err)
}

b := session.NewBatch(LoggedBatch)
b.WithNowInSeconds(0)
b.Query("INSERT INTO batch_now_in_seconds (id, val) VALUES (?, ?) USING TTL 20", 1, "val")
if err := session.ExecuteBatch(b); err != nil {
t.Fatal(err)
}

var remainingTTL int
err := session.Query(`SELECT TTL(val) FROM batch_now_in_seconds WHERE id = ?`, 1).
WithNowInSeconds(10).
Scan(&remainingTTL)
if err != nil {
t.Fatal(err)
}

require.Equal(t, remainingTTL, 10)
}

func TestBatch_SetKeyspace(t *testing.T) {
session := createSession(t)
defer session.Close()

if session.cfg.ProtoVersion < protoVersion5 {
t.Skip("keyspace for BATCH message is not supported in protocol < 5")
}

const keyspaceStmt = `
CREATE KEYSPACE IF NOT EXISTS gocql_keyspace_override_test
WITH replication = {
'class': 'SimpleStrategy',
'replication_factor': '1'
};
`

err := session.Query(keyspaceStmt).Exec()
if err != nil {
t.Fatal(err)
}

err = createTable(session, "CREATE TABLE IF NOT EXISTS gocql_keyspace_override_test.batch_keyspace(id int, value text, PRIMARY KEY (id))")
if err != nil {
t.Fatal(err)
}

ids := []int{1, 2}
texts := []string{"val1", "val2"}

b := session.NewBatch(LoggedBatch).SetKeyspace("gocql_keyspace_override_test")
b.Query("INSERT INTO batch_keyspace(id, value) VALUES (?, ?)", ids[0], texts[0])
b.Query("INSERT INTO batch_keyspace(id, value) VALUES (?, ?)", ids[1], texts[1])
err = session.ExecuteBatch(b)
if err != nil {
t.Fatal(err)
}

var (
id int
text string
)

iter := session.Query("SELECT * FROM gocql_keyspace_override_test.batch_keyspace").Iter()
defer iter.Close()

for i := 0; iter.Scan(&id, &text); i++ {
require.Equal(t, id, ids[i])
require.Equal(t, text, texts[i])
}
}
Loading
Loading