You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
124 lines
6.0 KiB
124 lines
6.0 KiB
package tools;
|
|
|
|
import io.confluent.kafka.schemaregistry.client.CachedSchemaRegistryClient;
|
|
import io.confluent.kafka.schemaregistry.client.SchemaRegistryClient;
|
|
import org.apache.avro.Schema;
|
|
import org.apache.avro.SchemaBuilder;
|
|
|
|
public class SchemaRegistryTest {
|
|
private static final String SCHEMA_REGISTRY_URL = "http://localhost:8081";
|
|
|
|
public static void main(String[] args) {
|
|
System.out.println("================================================================================");
|
|
System.out.println("Schema Registry Test - Verifying In-Memory Read Optimization");
|
|
System.out.println("================================================================================\n");
|
|
|
|
SchemaRegistryClient schemaRegistry = new CachedSchemaRegistryClient(SCHEMA_REGISTRY_URL, 100);
|
|
boolean allTestsPassed = true;
|
|
|
|
try {
|
|
// Test 1: Register first schema
|
|
System.out.println("Test 1: Registering first schema (user-value)...");
|
|
Schema userValueSchema = SchemaBuilder
|
|
.record("User").fields()
|
|
.requiredString("name")
|
|
.requiredInt("age")
|
|
.endRecord();
|
|
|
|
long startTime = System.currentTimeMillis();
|
|
int schema1Id = schemaRegistry.register("user-value", userValueSchema);
|
|
long elapsedTime = System.currentTimeMillis() - startTime;
|
|
System.out.println("✓ SUCCESS: Schema registered with ID: " + schema1Id + " (took " + elapsedTime + "ms)");
|
|
|
|
// Test 2: Register second schema immediately (tests read-after-write)
|
|
System.out.println("\nTest 2: Registering second schema immediately (user-key)...");
|
|
Schema userKeySchema = SchemaBuilder
|
|
.record("UserKey").fields()
|
|
.requiredString("userId")
|
|
.endRecord();
|
|
|
|
startTime = System.currentTimeMillis();
|
|
int schema2Id = schemaRegistry.register("user-key", userKeySchema);
|
|
elapsedTime = System.currentTimeMillis() - startTime;
|
|
System.out.println("✓ SUCCESS: Schema registered with ID: " + schema2Id + " (took " + elapsedTime + "ms)");
|
|
|
|
// Test 3: Rapid fire registrations (tests concurrent writes)
|
|
System.out.println("\nTest 3: Rapid fire registrations (10 schemas in parallel)...");
|
|
startTime = System.currentTimeMillis();
|
|
Thread[] threads = new Thread[10];
|
|
final boolean[] results = new boolean[10];
|
|
|
|
for (int i = 0; i < 10; i++) {
|
|
final int index = i;
|
|
threads[i] = new Thread(() -> {
|
|
try {
|
|
Schema schema = SchemaBuilder
|
|
.record("Test" + index).fields()
|
|
.requiredString("field" + index)
|
|
.endRecord();
|
|
schemaRegistry.register("test-" + index + "-value", schema);
|
|
results[index] = true;
|
|
} catch (Exception e) {
|
|
System.err.println("✗ ERROR in thread " + index + ": " + e.getMessage());
|
|
results[index] = false;
|
|
}
|
|
});
|
|
threads[i].start();
|
|
}
|
|
|
|
for (Thread thread : threads) {
|
|
thread.join();
|
|
}
|
|
|
|
elapsedTime = System.currentTimeMillis() - startTime;
|
|
int successCount = 0;
|
|
for (boolean result : results) {
|
|
if (result) successCount++;
|
|
}
|
|
|
|
if (successCount == 10) {
|
|
System.out.println("✓ SUCCESS: All 10 schemas registered (took " + elapsedTime + "ms total, ~" + (elapsedTime / 10) + "ms per schema)");
|
|
} else {
|
|
System.out.println("✗ PARTIAL FAILURE: Only " + successCount + "/10 schemas registered");
|
|
allTestsPassed = false;
|
|
}
|
|
|
|
// Test 4: Verify we can retrieve all schemas
|
|
System.out.println("\nTest 4: Verifying all schemas are retrievable...");
|
|
startTime = System.currentTimeMillis();
|
|
Schema retrieved1 = schemaRegistry.getById(schema1Id);
|
|
Schema retrieved2 = schemaRegistry.getById(schema2Id);
|
|
elapsedTime = System.currentTimeMillis() - startTime;
|
|
|
|
if (retrieved1.equals(userValueSchema) && retrieved2.equals(userKeySchema)) {
|
|
System.out.println("✓ SUCCESS: All schemas retrieved correctly (took " + elapsedTime + "ms)");
|
|
} else {
|
|
System.out.println("✗ FAILURE: Schema mismatch");
|
|
allTestsPassed = false;
|
|
}
|
|
|
|
// Summary
|
|
System.out.println("\n===============================================================================");
|
|
if (allTestsPassed) {
|
|
System.out.println("✓ ALL TESTS PASSED!");
|
|
System.out.println("===============================================================================");
|
|
System.out.println("\nOptimization verified:");
|
|
System.out.println("- ForceFlush is NO LONGER NEEDED");
|
|
System.out.println("- Subscribers read from in-memory buffer using IsOffsetInMemory()");
|
|
System.out.println("- Per-subscriber notification channels provide instant wake-up");
|
|
System.out.println("- True concurrent writes without serialization");
|
|
System.exit(0);
|
|
} else {
|
|
System.out.println("✗ SOME TESTS FAILED");
|
|
System.out.println("===============================================================================");
|
|
System.exit(1);
|
|
}
|
|
|
|
} catch (Exception e) {
|
|
System.err.println("\n✗ FATAL ERROR: " + e.getMessage());
|
|
e.printStackTrace();
|
|
System.exit(1);
|
|
}
|
|
}
|
|
}
|
|
|