/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you 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 org.apache.jena.hadoop.rdf.io.input; import java.io.IOException; import java.io.OutputStream; import java.nio.charset.Charset; import org.apache.jena.graph.Triple ; import org.apache.jena.hadoop.rdf.types.TripleWritable; import org.apache.jena.rdf.model.Model ; import org.apache.jena.rdf.model.ModelFactory ; import org.apache.jena.rdf.model.Property ; import org.apache.jena.rdf.model.Resource ; import org.apache.jena.riot.Lang; import org.apache.jena.riot.RDFDataMgr; /** * Abstract tests for Triple input formats * * * */ public abstract class AbstractWholeFileTripleInputFormatTests extends AbstractNodeTupleInputFormatTests<Triple, TripleWritable> { private static final Charset utf8 = Charset.forName("utf-8"); @Override protected boolean canSplitInputs() { return false; } private void writeTuples(Model m, OutputStream output) { RDFDataMgr.write(output, m, this.getRdfLanguage()); } /** * Gets the RDF language to write out generate tuples in * @return RDF language */ protected abstract Lang getRdfLanguage(); @Override protected final void generateTuples(OutputStream output, int num) throws IOException { Model m = ModelFactory.createDefaultModel(); Resource currSubj = m.createResource("http://example.org/subjects/0"); Property predicate = m.createProperty("http://example.org/predicate"); for (int i = 0; i < num; i++) { if (i % 10 == 0) { currSubj = m.createResource("http://example.org/subjects/" + (i / 10)); } m.add(currSubj, predicate, m.createTypedLiteral(i)); } this.writeTuples(m, output); output.close(); } @Override protected final void generateMixedTuples(OutputStream output, int num) throws IOException { // Write good data Model m = ModelFactory.createDefaultModel(); Resource currSubj = m.createResource("http://example.org/subjects/0"); Property predicate = m.createProperty("http://example.org/predicate"); for (int i = 0; i < num / 2; i++) { if (i % 10 == 0) { currSubj = m.createResource("http://example.org/subjects/" + (i / 10)); } m.add(currSubj, predicate, m.createTypedLiteral(i)); } this.writeTuples(m, output); // Write junk data byte[] junk = "junk data\n".getBytes(utf8); for (int i = 0; i < num / 2; i++) { output.write(junk); } output.flush(); output.close(); } @Override protected final void generateBadTuples(OutputStream output, int num) throws IOException { byte[] junk = "junk data\n".getBytes(utf8); for (int i = 0; i < num; i++) { output.write(junk); } output.flush(); output.close(); } }