use of com.hortonworks.registries.schemaregistry.SchemaVersionKey in project registry by hortonworks.
the class LocalRegistryServerHATest method testHASanity.
@Test
public void testHASanity() throws Exception {
SchemaRegistryTestServerClientWrapper followerServer = followerSchemaRegistryServer();
SchemaRegistryClient schemaRegistryClient = followerServer.getClient();
// registering schema metadata on follower, this should have been redirected to leader.
String schemaName = "foo";
SchemaMetadata schemaMetadata = new SchemaMetadata.Builder(schemaName).type("avro").build();
Long schemaId = schemaRegistryClient.registerSchemaMetadata(schemaMetadata);
Assert.assertNotNull(schemaId);
// registering a new schema on follower, this should have been redirected to leader.
String schema1 = IOUtils.toString(LocalRegistryServerTest.class.getResourceAsStream("/schema-1.avsc"), "UTF-8");
SchemaIdVersion v1 = schemaRegistryClient.addSchemaVersion(schemaName, new SchemaVersion(schema1, "Initial version of the schema"));
// retrieve schema on leader as the schema data is stored in memory in leader. this data does not exist on
// followers as the storage is inmemory.
SchemaRegistryTestServerClientWrapper leaderServer = leaderSchemaRegistryServer();
int leaderPort = leaderServer.getLocalPort();
SchemaRegistryClient leaderClient = leaderServer.getClient();
SchemaMetadataInfo schemaMetadataInfo = leaderClient.getSchemaMetadataInfo(schemaName);
Assert.assertEquals(schemaMetadata, schemaMetadataInfo.getSchemaMetadata());
// stop the leader server
leaderServer.stopTestServer();
// get the new leader server and run operations.
SchemaRegistryTestServerClientWrapper newLeaderServer = leaderSchemaRegistryServer();
Assert.assertNotEquals(leaderPort, newLeaderServer.getLocalPort());
leaderClient = newLeaderServer.getClient();
String receivedSchema = leaderClient.getSchemaVersionInfo(new SchemaVersionKey(schemaName, v1.getVersion())).getSchemaText();
Assert.assertEquals(schema1, receivedSchema);
}
use of com.hortonworks.registries.schemaregistry.SchemaVersionKey in project registry by hortonworks.
the class AbstractAvroSnapshotDeserializer method buildDeserializedObject.
/**
* Builds the deserialized object from the given {@code payloadInputStream} and applying writer and reader schemas
* from the respective given versions.
*
* @param protocolId protocol id
* @param payloadInputStream payload
* @param schemaMetadata metadata about schema
* @param writerSchemaVersion schema version of the writer
* @param readerSchemaVersion schema version to be applied for reading or projection
* @return the deserialized object
* @throws SerDesException when any ser/des error occurs
*/
protected Object buildDeserializedObject(byte protocolId, InputStream payloadInputStream, SchemaMetadata schemaMetadata, Integer writerSchemaVersion, Integer readerSchemaVersion) throws SerDesException {
Object deserializedObj;
String schemaName = schemaMetadata.getName();
SchemaVersionKey writerSchemaVersionKey = new SchemaVersionKey(schemaName, writerSchemaVersion);
LOG.debug("SchemaKey: [{}] for the received payload", writerSchemaVersionKey);
Schema writerSchema = getSchema(writerSchemaVersionKey);
if (writerSchema == null) {
throw new RegistryException("No schema exists with metadata-key: " + schemaMetadata + " and writerSchemaVersion: " + writerSchemaVersion);
}
Schema readerSchema = readerSchemaVersion != null ? getSchema(new SchemaVersionKey(schemaName, readerSchemaVersion)) : null;
deserializedObj = deserializePayloadForProtocol(protocolId, payloadInputStream, writerSchema, readerSchema);
return deserializedObj;
}
use of com.hortonworks.registries.schemaregistry.SchemaVersionKey in project registry by hortonworks.
the class SchemaRegistryResource method getSchemaVersion.
@GET
@Path("/schemas/{name}/versions/{version}")
@ApiOperation(value = "Get a version of the schema identified by the schema name", response = SchemaVersionInfo.class, tags = OPERATION_GROUP_SCHEMA)
@Timed
@UnitOfWork
public Response getSchemaVersion(@ApiParam(value = "Schema name", required = true) @PathParam("name") String schemaMetadata, @ApiParam(value = "version of the schema", required = true) @PathParam("version") Integer versionNumber) {
SchemaVersionKey schemaVersionKey = new SchemaVersionKey(schemaMetadata, versionNumber);
Response response;
try {
SchemaVersionInfo schemaVersionInfo = schemaRegistry.getSchemaVersionInfo(schemaVersionKey);
response = WSUtils.respondEntity(schemaVersionInfo, Response.Status.OK);
} catch (SchemaNotFoundException e) {
LOG.info("No schemas found with schemaVersionKey: [{}]", schemaVersionKey);
response = WSUtils.respond(Response.Status.NOT_FOUND, CatalogResponse.ResponseMessage.ENTITY_NOT_FOUND, schemaVersionKey.toString());
} catch (Exception ex) {
LOG.error("Encountered error while getting all schema versions for schemakey [{}]", schemaMetadata, ex);
response = WSUtils.respond(Response.Status.INTERNAL_SERVER_ERROR, CatalogResponse.ResponseMessage.EXCEPTION, ex.getMessage());
}
return response;
}
use of com.hortonworks.registries.schemaregistry.SchemaVersionKey in project registry by hortonworks.
the class BasicSchemaRegistryClientOpsTest method doTestSchemaOps.
private void doTestSchemaOps(SchemaValidationLevel validationLevel) throws IOException, InvalidSchemaException, IncompatibleSchemaException, SchemaNotFoundException, SchemaBranchNotFoundException {
String testName = TEST_NAME_RULE.getMethodName();
SchemaMetadata schemaMetadata = new SchemaMetadata.Builder(testName + "-schema").type(AvroSchemaProvider.TYPE).schemaGroup(testName + "-group").description("Schema for " + testName).validationLevel(validationLevel).compatibility(SchemaCompatibility.BOTH).build();
Long id = schemaRegistryClient.registerSchemaMetadata(schemaMetadata);
Assert.assertNotNull(id);
// registering a new schema
String schemaName = schemaMetadata.getName();
String schema1 = AvroSchemaRegistryClientUtil.getSchema("/schema-1.avsc");
SchemaIdVersion v1 = schemaRegistryClient.addSchemaVersion(schemaName, new SchemaVersion(schema1, "Initial version of the schema"));
Assert.assertNotNull(v1.getSchemaMetadataId());
Assert.assertEquals(1, v1.getVersion().intValue());
SchemaMetadataInfo schemaMetadataInfoForId = schemaRegistryClient.getSchemaMetadataInfo(v1.getSchemaMetadataId());
SchemaMetadataInfo schemaMetadataInfoForName = schemaRegistryClient.getSchemaMetadataInfo(schemaName);
Assert.assertEquals(schemaMetadataInfoForId, schemaMetadataInfoForName);
// adding a new version of the schema using uploadSchemaVersion API
SchemaIdVersion v2 = schemaRegistryClient.uploadSchemaVersion(schemaMetadata.getName(), "second version", AvroSchemaRegistryClientTest.class.getResourceAsStream("/schema-2.avsc"));
Assert.assertEquals(v1.getVersion() + 1, v2.getVersion().intValue());
SchemaVersionInfo schemaVersionInfo = schemaRegistryClient.getSchemaVersionInfo(new SchemaVersionKey(schemaName, v2.getVersion()));
SchemaVersionInfo latest = schemaRegistryClient.getLatestSchemaVersionInfo(schemaName);
Assert.assertEquals(latest, schemaVersionInfo);
Collection<SchemaVersionInfo> allVersions = schemaRegistryClient.getAllVersions(schemaName);
Assert.assertEquals(2, allVersions.size());
// receive the same version as earlier without adding a new schema entry as it exists in the same schema group.
SchemaIdVersion version = schemaRegistryClient.addSchemaVersion(schemaMetadata, new SchemaVersion(schema1, "already added schema"));
Assert.assertEquals(version, v1);
Collection<SchemaVersionKey> md5SchemaVersionKeys = schemaRegistryClient.findSchemasByFields(new SchemaFieldQuery.Builder().name("md5").build());
Assert.assertEquals(2, md5SchemaVersionKeys.size());
Collection<SchemaVersionKey> txidSchemaVersionKeys = schemaRegistryClient.findSchemasByFields(new SchemaFieldQuery.Builder().name("txid").build());
Assert.assertEquals(1, txidSchemaVersionKeys.size());
// checks we can update schema meta data.
SchemaMetadata currentSchemaMetadata = schemaRegistryClient.getSchemaMetadataInfo(schemaName).getSchemaMetadata();
SchemaMetadata schemaMetadataToUpdateTo = new SchemaMetadata.Builder(currentSchemaMetadata).validationLevel(SchemaValidationLevel.LATEST).build();
SchemaMetadataInfo updatedSchemaMetadata = schemaRegistryClient.updateSchemaMetadata(schemaName, schemaMetadataToUpdateTo);
Assert.assertEquals(SchemaValidationLevel.LATEST, updatedSchemaMetadata.getSchemaMetadata().getValidationLevel());
}
use of com.hortonworks.registries.schemaregistry.SchemaVersionKey in project registry by hortonworks.
the class AvroSchemaResolver method traverseIncludedSchemaTypes.
private Map<String, Schema> traverseIncludedSchemaTypes(String schemaText, Map<String, SchemaParsingState> schemaParsingStates) throws InvalidSchemaException, SchemaNotFoundException {
List<SchemaVersionKey> includedSchemaVersions = getIncludedSchemaVersions(schemaText);
if (includedSchemaVersions == null || includedSchemaVersions.isEmpty()) {
return Collections.emptyMap();
}
Map<String, Schema> schemaTypes = new HashMap<>();
for (SchemaVersionKey schemaVersionKey : includedSchemaVersions) {
Map<String, Schema> collectedSchemas = collectSchemaTypes(schemaVersionKey, schemaParsingStates);
if (collectedSchemas != null) {
schemaTypes.putAll(collectedSchemas);
}
}
return schemaTypes;
}
Aggregations