/** * Copyright 2016 Confluent Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. **/ package io.confluent.kafka.schemaregistry.maven; import io.confluent.kafka.schemaregistry.client.MockSchemaRegistryClient; import org.apache.avro.Schema; import org.apache.maven.plugin.MojoExecutionException; import org.apache.maven.plugin.MojoFailureException; import org.hamcrest.core.IsEqual; import org.junit.After; import org.junit.Assert; import org.junit.Before; import org.junit.Test; import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.util.Arrays; import java.util.LinkedHashMap; import java.util.Map; public class RegisterSchemaRegistryMojoTest extends SchemaRegistryTest{ RegisterSchemaRegistryMojo mojo; @Before public void createMojo(){ this.mojo = new RegisterSchemaRegistryMojo(); this.mojo.client(new MockSchemaRegistryClient()); } @Test public void register() throws IOException, MojoFailureException, MojoExecutionException { Map<String, Integer> expectedVersions = new LinkedHashMap<>(); Map<String, File> subjectToFile = new LinkedHashMap<>(); int version = 1; for (int i = 0; i < 100; i++) { String keySubject = String.format("TestSubject%03d-key", i); String valueSubject = String.format("TestSubject%03d-value", i); Schema keySchema = Schema.create(Schema.Type.STRING); Schema valueSchema = Schema.createUnion(Arrays.asList(Schema.create(Schema.Type.STRING), Schema.create(Schema.Type.NULL))); File keySchemaFile = new File(this.tempDirectory, keySubject + ".avsc"); File valueSchemaFile = new File(this.tempDirectory, valueSubject + ".avsc"); writeSchema(keySchemaFile, keySchema); writeSchema(valueSchemaFile, valueSchema); subjectToFile.put(keySubject, keySchemaFile); expectedVersions.put(keySubject, version++); subjectToFile.put(valueSubject, valueSchemaFile); expectedVersions.put(valueSubject, version++); } this.mojo.subjects = subjectToFile; this.mojo.execute(); Assert.assertThat(this.mojo.schemaVersions, IsEqual.equalTo(expectedVersions)); } @Test(expected = IllegalStateException.class) public void malformedSchema() throws IOException, MojoFailureException, MojoExecutionException { Map<String, Integer> expectedVersions = new LinkedHashMap<>(); Map<String, File> subjectToFile = new LinkedHashMap<>(); int version = 1; for (int i = 0; i < 100; i++) { String keySubject = String.format("TestSubject%03d-key", i); String valueSubject = String.format("TestSubject%03d-value", i); Schema keySchema = Schema.create(Schema.Type.STRING); Schema valueSchema = Schema.createUnion(Arrays.asList(Schema.create(Schema.Type.STRING), Schema.create(Schema.Type.NULL))); File keySchemaFile = new File(this.tempDirectory, keySubject + ".avsc"); File valueSchemaFile = new File(this.tempDirectory, valueSubject + ".avsc"); if (i % 7 == 0) { writeMalformedFile(keySchemaFile); writeMalformedFile(valueSchemaFile); } subjectToFile.put(keySubject, keySchemaFile); expectedVersions.put(keySubject, version++); subjectToFile.put(valueSubject, valueSchemaFile); expectedVersions.put(valueSubject, version++); } this.mojo.subjects = subjectToFile; this.mojo.execute(); } @Test(expected = IllegalStateException.class) public void missingSchemas() throws IOException, MojoFailureException, MojoExecutionException { Map<String, Integer> expectedVersions = new LinkedHashMap<>(); Map<String, File> subjectToFile = new LinkedHashMap<>(); int version = 1; for (int i = 0; i < 100; i++) { String keySubject = String.format("TestSubject%03d-key", i); String valueSubject = String.format("TestSubject%03d-value", i); Schema keySchema = Schema.create(Schema.Type.STRING); Schema valueSchema = Schema.createUnion(Arrays.asList(Schema.create(Schema.Type.STRING), Schema.create(Schema.Type.NULL))); File keySchemaFile = new File(this.tempDirectory, keySubject + ".avsc"); File valueSchemaFile = new File(this.tempDirectory, valueSubject + ".avsc"); if (i % 7 == 0) { writeSchema(keySchemaFile, keySchema); writeSchema(valueSchemaFile, valueSchema); } subjectToFile.put(keySubject, keySchemaFile); expectedVersions.put(keySubject, version++); subjectToFile.put(valueSubject, valueSchemaFile); expectedVersions.put(valueSubject, version++); } this.mojo.subjects = subjectToFile; this.mojo.execute(); } }