Skip to content

Commit

Permalink
test/topology_experimental_raft: Prevent keyspace creation conflicts …
Browse files Browse the repository at this point in the history
…with IF NOT EXISTS

Background:

- Python driver exhibits unexpected behavior causing duplicate keyspace creation attempts (scylladb/python-driver#317)

- Existing test cases can fail with cassandra.AlreadyExists exception:

  ```
  cassandra.AlreadyExists: Keyspace 'test_1732631552019_lxagp' already exists
  ```

Resolution:

- Added `IF NOT EXISTS` clause to keyspace and table creation statements
- Mitigates potential race conditions during test setup
- Aligns with previous mitigation approach in commit 8876b9b

Specific Changes:

- Ensures safe keyspace creation in concurrent test scenarios
- Prevents test failures due to duplicate keyspace generation

Fixes scylladb#21701
Signed-off-by: Kefu Chai <[email protected]>
  • Loading branch information
tchaikov committed Dec 19, 2024
1 parent 0ea069a commit 77d5ccb
Showing 1 changed file with 2 additions and 2 deletions.
4 changes: 2 additions & 2 deletions test/topology_experimental_raft/test_tablets.py
Original file line number Diff line number Diff line change
Expand Up @@ -1550,8 +1550,8 @@ async def create_and_populate_table(manager: ManagerClient, rf: int = 3, initial

cql = manager.get_cql()
try:
await cql.run_async(f"CREATE KEYSPACE {ks} WITH replication = {{'class': 'NetworkTopologyStrategy', 'replication_factor': {rf}}} AND tablets = {{'initial': {initial_tablets}}}")
await cql.run_async(f"CREATE TABLE {ks}.{table} (pk int PRIMARY KEY, c int)")
await cql.run_async(f"CREATE KEYSPACE IF NOT EXISTS {ks} WITH replication = {{'class': 'NetworkTopologyStrategy', 'replication_factor': {rf}}} AND tablets = {{'initial': {initial_tablets}}}")
await cql.run_async(f"CREATE TABLE IF NOT EXISTS {ks}.{table} (pk int PRIMARY KEY, c int)")
await asyncio.gather(*[cql.run_async(f"INSERT INTO {ks}.{table} (pk, c) VALUES ({k}, 1);") for k in range(num_keys)])
yield TestContext(ks, table, rf, initial_tablets, num_keys)
finally:
Expand Down

0 comments on commit 77d5ccb

Please sign in to comment.